• 2021-02-05:给定一个数N,想象只由0和1两种字符,组成的所有长度为N的字符串。如果某个字符串,任何0字符的左边都有1紧挨着,认为这个字符串达标。请问有多少达标的字符串?


    2021-02-05:给定一个数N,想象只由0和1两种字符,组成的所有长度为N的字符串。如果某个字符串,任何0字符的左边都有1紧挨着,认为这个字符串达标。请问有多少达标的字符串?

    福哥答案2021-02-05:
    举例:
    N=6
    [1 0 1 0 1 0]
    [1 0 1 0 1 1]
    [1 0 1 1 0 1]
    [1 0 1 1 1 0]
    [1 0 1 1 1 1]
    [1 1 0 1 0 1]
    [1 1 0 1 1 0]
    [1 1 0 1 1 1]
    [1 1 1 0 1 0]
    [1 1 1 0 1 1]
    [1 1 1 1 0 1]
    [1 1 1 1 1 0]
    [1 1 1 1 1 1]
    总共13种。

    这道题是斐波那契数列。代码不用斐波那契数列,用递归最直观。

    代码用golang编写,代码如下:

    package main
    
    import "fmt"
    
    func main() {
        for i := 1; i <= 10; i++ {
            ret := ff(i)
            fmt.Println(i, ret)
        }
    }
    
    //一个一个试,最直观思维
    func ff(n int) int {
        ansval := 0
        ans := &ansval
        arr := make([]int, n)
        //第0个位置,肯定是1
        arr[0] = 1
        process(arr, 1, ans)
        return *ans
    }
    
    //递归
    func process(arr []int, start int, ans *int) {
        if start == len(arr) {
            *ans++
            return
        }
        if arr[start-1] == 1 {
            arr[start] = 0
            process(arr, start+1, ans)
        }
        arr[start] = 1
        process(arr, start+1, ans)
    }
    

      

    代码结果如下:

    [左神java代码](https://github.com/algorithmzuo/algorithmbasic2020/blob/master/src/class26/Code02_FibonacciProblem.java)
    [评论](https://user.qzone.qq.com/3182319461/blog/1612479635)

  • 相关阅读:
    [leetcode] Combinations
    Binary Tree Level Order Traversal I II
    [leetcode] Remove Duplicates from Sorted Array I II
    [leetcode] Permutations II
    [leetcode] Permutations
    如何在线程间进行事件通知?
    如何实现迭代对象和迭代器对象?
    如何判断字符串a是否以字符串 b开头或者结尾?
    如何实现用户的历史记录功能(最多n条)?
    如何让字典保持有序?
  • 原文地址:https://www.cnblogs.com/waitmoon/p/14379963.html
Copyright © 2020-2023  润新知