继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Golang洗牌算法,抢红包算法

慕哥9229398
关注TA
已关注
手记 1099
粉丝 199
获赞 913

webp

Golang

1. 洗牌算法

洗牌算法,即将原来的顺序打乱,组成新的随机排序的顺序。

以下示例中以int切片为例给出一个简单算法:

import (    "fmt"
    "math/rand"
    "time")func main() {
    intArr := []int{1,2,3,4,5,6,7,8,9}    for i := 0; i < 10; i++{
        shuffle(intArr)
        fmt.Println(intArr)
    }
}// 洗牌算法func shuffle(arr []int){
    rand.Seed(time.Now().UnixNano())
    var i, j int
    var temp int
    for i = len(arr) - 1; i > 0; i-- {
        j = rand.Intn(i + 1)
        temp = arr[i]
        arr[i] = arr[j]
        arr[j] = temp
    }
}

测试结果


webp

测试结果

2. 抢红包算法

抢红包算法即类似微信拼手气红包,发一定金额的红包,指定人数抢红包。

以下给出一个简单的算法示例:

import (    "fmt"
    "math/rand"
    "time")func main() {    for i := 0; i < 10; i ++{
        redPackage(10, 500)
        fmt.Println("")
    }
}// 随机红包// remainCount: 剩余红包数// remainMoney: 剩余红包金额(单位:分)func randomMoney(remainCount, remainMoney int)int{    if remainCount == 1{        return remainMoney
    }

    rand.Seed(time.Now().UnixNano())

    var min = 1
    max := remainMoney / remainCount * 2
    money := rand.Intn(max) + min    return money
}// 发红包// count: 红包数量// money: 红包金额(单位:分)func redPackage(count, money int)  {    for i := 0; i < count; i++ {
        m := randomMoney(count - i, money)
        fmt.Printf("%d  ",  m)
        money -= m
    }
}

测试结果:


webp

测试结果



作者:ChainZhang
链接:https://www.jianshu.com/p/15783f067133


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP