天气与日历 切换到窄版

 找回密码
 立即注册
中国膜结构网
十大进口膜材评选 十大国产膜材评选 十大膜结构设计评选 十大膜结构公司评选
查看: 77|回复: 0

C++ 洗牌算法

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
洗牌算法
与打乱数组顺序有关的题目,要求位置交换的概率相等。
证明: 放在第一个位置的元素,取0-n 的随机数,概率为 1/n;
放在第二个位置的元素,取1到n 的随机数,概率为 (1-1/n)* 1/(n-1) = 1/n;

void shuffle(vector<int>& nums){
        int n = nums.size();
        if (n<=0) return ;
        for(int i=0;i<n;i++){
                int index = i + rand() % (n-i);
                swap(nums[index], nums[i]);
        }
}

 

 

 

 

C++ 洗牌算法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|中国膜结构网|中国膜结构协会|进口膜材|国产膜材|ETFE|PVDF|PTFE|设计|施工|安装|车棚|看台|污水池|中国膜结构网_中国空间膜结构协会

GMT+8, 2024-11-1 10:36 , Processed in 0.136440 second(s), 28 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表