随机化算法

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

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

无论你是欧皇还是非酋,在大量尝试次数下众生平等

生成随机数

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 @   wljss  阅读(178)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示