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

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

    对拍

    这里

    模拟退火

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

    这里

  • 相关阅读:
    设计模式
    Lambda表达式
    网络通信
    排序
    可变参数
    反弹shell学习总结
    Apache Flink任意Jar包上传导致远程代码执行漏洞复现
    定时执行rsync同步数据以及mysql备份
    python练习
    django 模型生成sql(多对多)
  • 原文地址:https://www.cnblogs.com/wljss/p/14966588.html
Copyright © 2011-2022 走看看