go递归

1.递归的使用

package main

import (
    "fmt"
    "time"
)

func fibnum(i int) int{
    if i==0{
        return 0
    }
    if i==1{
        return 1
    }
    fmt.Println("i is",i)
    return fibnum(i-1)+fibnum(i-2)

}

func testthis(i int)  {
    if i==1{
        fmt.Println("i is 1 ,out this")
        return
    }
    if i==10{
        fmt.Println("i is 10,out this")
        return
    }
    fmt.Println("begin test; and i is now:",i)
    time.Sleep(time.Second*1)
    testthis(i-1)
    fmt.Println("when i will be print??")
    fmt.Println("i now is:",i)
    testthis(i+1)
    fmt.Println("test done, and i is now: ",i)
}


func main()  {

    fmt.Println(fibnum(3))
    testthis(5)

}

使用递归快速排序

package main

import "fmt"

func quicksort(array []int, begin, end int, mark string) {
    var i, j int
    if begin < end {
        i = begin + 1 // 将array[begin]作为基准数,因此从array[begin+1]开始与基准数比较!
        j = end       // array[end]是数组的最后一位

        for {
            if i >= j {
                break
            }
            if array[i] > array[begin] {
                array[i], array[j] = array[j], array[i]
                j = j - 1
            } else {
                i = i + 1              //此处放在else内,很重要,二分思想!
            }

        }
        //fmt.Println("array and i and j is",array,i,j)
        if array[i] >= array[begin] { 
            i = i - 1
        }

        array[begin], array[i] = array[i], array[begin]
        //fmt.Printf("%s>sort:%v\n", mark, array[begin:end])
        fmt.Println("array and i and j is",array,i,j)
        fmt.Printf("%s>%v,%d,%v\n", mark, array[begin:i], array[i], array[j:])   //后标取不到
        quicksort(array, begin, i, mark+"--")
        quicksort(array, j, end, mark+"--")
    }
}

func main() {

    nums := []int{12, 85, 25, 16, 34, 23, 49, 95, 17, 61}
    fmt.Printf("begin:%#v\n", nums)

    mark := "--"
    quicksort(nums, 0, len(nums)-1, mark)
    fmt.Printf("last:%#v\n", nums)
}

2.关于递归上下文的测试

package main

import (
    "fmt"
)


var i int = 0


func testagain(step int){

    if step==5{
        //fmt.Println(a)
        return
    }
    fmt.Println("begin i is:",i)
    i++
    testagain(step+1)
    fmt.Println("after i is",i)
    i--
    return

}
func main(){
    testagain(1)
}

运行的结果如下:

begin i is: 0
begin i is: 1
begin i is: 2
begin i is: 3
after i is 4
after i is 3
after i is 2
after i is 1
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文有七千字,阅读大约需要占用你10分钟时间。 好吧。。随便写的,我也不知道会花多久看完。因为写的比较烂,而且只是...
    锅与盆阅读 12,557评论 5 36
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 9,079评论 0 15
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,583评论 0 52
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 5,013评论 0 2
  • 现象:在别的男生的评论区里:女友去评论的时候,想秀一下恩爱。可是女友并不喜欢这样做。几乎对你的评论特别无视,也几...
    唐牛牛Fly阅读 1,306评论 0 0