洗牌算法
洗牌算法
洗牌算法,刚在知乎这个回答上看到的一个算法,非常有趣。
通过概率论的知识原地实现了一个公平的随机算法。
大致的过程就是一个数组(假设有n个数),从后往前取第一个数A,第二个数随机从前面的数据中选取。最后算下来随机的概率是1/n。
代码如下
/**
* @program: erp-user
* @description:
* @author: lkb
* @create: 2020-01-16 13:22
*/
public class Test {
public static void main(String[] args) {
int[] arr = new int[]{6,34,27,4,9};
System.out.println("初始数组:");
Arrays.stream(arr).forEach(d-> System.out.print(d +", "));
System.out.println();
for(int i=arr.length-1;i>0;i--){
int j = new Random().nextInt(i);
swap(arr,i,j);
System.out.println(arr[i] +" <-> " + arr[j] );
Arrays.stream(arr).forEach(d-> System.out.print(d +", "));
System.out.println();
}
}
private static void swap(int[] arr, int a,int b){
int tmp = arr[a];
arr[a] = arr[b];
arr[b] = tmp;
}
}
欢迎关注我的公众号 -- 大白和小倔
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!