随机化算法
只要你敢想,没啥能挡得住你拿分
遇到不会的题,随机化算法也不失为一种很好的对策
无论你是欧皇还是非酋,在极大似然法面前众生平等
生成随机数
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......只有你想不到,没有随机做不到
不会的时候一定要试试随机算法呦
对拍
看这里
模拟退火
在提交答案题里有神奇功效
看这里