约瑟夫环问题的解法

发布时间:2022-07-04 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了约瑟夫环问题的解法脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

两种解法:

一、使用双向链表

二、使用数组

两种实现的算法如下:

package go_package

import (
    "fmt"
    "testing"
)

tyPE Node struct {
    v int
    PRe *Node
    next *Node
}


/**
 * 使用node链表进行计算
 */
func TestMonkey(t *testing.T) {
    First := &Node{1, nil, nil}
    pre := &Node{2, nil, nil}
    first.next = pre
    pre.pre = first
    for i := 3; i<10; i++ {
        element := &Node{i, nil, nil}
        pre.next = element
        element.pre = pre
        pre = element
    }
    pre.next = first
    first.pre = pre

    result := handleNode(first, 5)
    fmt.Println("结果是: ", result)

    arr := []int{1,2,3,4,5,6,7,8,9}
    another := handleArray(arr, 5)
    fmt.Println("另一个结果是: ", another)



}


func handleNode(node *Node, m int) int{
    num := 0
    for node != node.next {
        num++
        if num == m {
            // 将当前node丢掉
            fmt.Println("current node is : ", node.v)
            pre := node.pre
            next := node.next
            pre.next = next
            next.pre = pre
            num = 0
            node = next
            continue
        }
        node = node.next
    }
    return node.v
}



func handleArray(arr []int, m int) int{
    num := 0
    mark := 0
    i := 0
    for mark < len(arr) - 1 {
        if i >= len(arr) {
            i = 0
        }
        if arr[i] == -1 {
            i++
            continue
        }
        num++
        if num == m {
            arr[i] = -1
            i++
            num = 0
            mark++
            continue
        }
        i++
    }
    result := 0
    for i,v := range arr {
        if v != -1 {
            result = i + 1
            break
        }
    }
    return result
}

 

脚本宝典总结

以上是脚本宝典为你收集整理的约瑟夫环问题的解法全部内容,希望文章能够帮你解决约瑟夫环问题的解法所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。