随机化算法

只要你敢想,没啥能挡得住你拿分

遇到不会的题,随机化算法也不失为一种很好的对策

无论你是欧皇还是非酋,在极大似然法面前众生平等

生成随机数

cout<<rand();会输出一个随机数,需要用到cstdlib库

但是,这些随机数是伪随机数,每次输出的都一样。

需要这么做srand(time(0));

其中srand()是用来更换rand()的参数,参数不同,随机数不同

time(0)则是返回自GMT时间1970年1月1日零点以来的秒数,不理解没关系,只要知道每次调用这个函数的时候返回的值不同就行。

注意:windows下和linux下生成的随机数范围不一样(一定要提前了解考试评测机的系统!)

windows下返回值较小,想要个大的怎么办?

define YYCH ((rand()<<14)|rand())

cout<<YYCH;

不用两个rand()相乘是因为这种做法不能生成质数

随机化乱搞

只要胆子大,搜索最优化

随机搜索,随机转移DP......只有你想不到,没有随机做不到

不会的时候一定要试试随机算法呦

对拍

这里

模拟退火

在提交答案题里有神奇功效

这里

posted @ 2021-07-16 19:39  wljss  阅读(166)  评论(0编辑  收藏  举报