zoukankan      html  css  js  c++  java
  • 随机化算法

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

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

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

    生成随机数

    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......只有你想不到,没有随机做不到

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

    对拍

    这里

    模拟退火

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

    这里

  • 相关阅读:
    MySQL使用alter修改表的结构
    MySQL基本库表管理
    MySQL的rpm安装教程
    MySQL基础理论
    Linux shell awk数组使用
    Linux shell awk逻辑控制语句
    Linux shell awk模式使用
    MySQL 查看执行计划
    MySQL 自定义函数
    MySQL 内置函数
  • 原文地址:https://www.cnblogs.com/wljss/p/14966588.html
Copyright © 2011-2022 走看看