当前位置: 首页 > news >正文

打卡信奥刷题(2536)用C++实现信奥 P2044 [NOI2012] 随机数生成器

P2044 [NOI2012] 随机数生成器

题目描述

栋栋最近迷上了随机算法,而随机数是生成随机算法的基础。栋栋准备使用线性同余法(Linear Congruential Method)来生成一个随机数列,这种方法需要设置四个非负整数参数m , a , c , X 0 m,a,c,X_0m,a,c,X0,按照下面的公式生成出一系列随机数{ X n } \{X_n\}{Xn}
X n + 1 = ( a X n + c ) m o d m X_{n+1}=(aX_n +c)\bmod mXn+1=(aXn+c)modm

其中m o d m \bmod mmodm表示前面的数除以m mm的余数。从这个式子可以看出,这个序列的下一个数总是由上一个数生成的。

用这种方法生成的序列具有随机序列的性质,因此这种方法被广泛地使用,包括常用的 C++ 和 Pascal 的产生随机数的库函数使用的也是这种方法。

栋栋知道这样产生的序列具有良好的随机性,不过心急的他仍然想尽快知道X n X_nXn是多少。由于栋栋需要的随机数是0 , 1 , … , g − 1 0,1,\dots,g-10,1,,g1之间的,他需要将X n X_nXn除以g gg取余得到他想要的数,即X n m o d g X_n \bmod gXnmodg,你只需要告诉栋栋他想要的数X n m o d g X_n \bmod gXnmodg是多少就可以了。

输入格式

一行6 66个用空格分割的整数m , a , c , X 0 , n m,a,c,X_0,nm,a,c,X0,ng gg,其中a , c , X 0 a,c,X_0a,c,X0是非负整数,m , n , g m,n,gm,n,g是正整数。

输出格式

输出一个数,即X n m o d g X_n \bmod gXnmodg

输入输出样例 #1

输入 #1

11 8 7 1 5 3

输出 #1

2

说明/提示

计算得X n = X 5 = 8 X_n=X_5=8Xn=X5=8,故( X n m o d g ) = ( 8 m o d 3 ) = 2 (X_n \bmod g) = (8 \bmod 3) = 2(Xnmodg)=(8mod3)=2

对于100 % 100\%100%的数据,n , m , a , c , X 0 ≤ 1 0 18 n,m,a,c,X_0\leq 10^{18}n,m,a,c,X010181 ≤ g ≤ 1 0 8 1\leq g\leq 10^81g108n , m ≥ 1 n,m\geq 1n,m1a , c , X 0 ≥ 0 a,c,X_0\geq 0a,c,X00

C++实现

#include<bits/stdc++.h>typedefunsignedlonglongull;usingnamespacestd;ull mod,a,c,x,n,g,mod1,m;ull ret,ans;inlineullmul(ull x,ull y){//龟速乘法for(ret=0;y;y>>=1){if(y&1)ret=(ret+x)%mod;x=(x+x)%mod;}returnret;}ullPow(ull a,ull k){//快速幂ull x=a;for(ans=1;k;k>>=1){if(k&1)ans=mul(ans,x);x=mul(x,x);}returnans;}ullSum(ull n,ull t){//n是长度 t是首项 m是公比if(n==1)returnt;ull ret=Sum(n/2,t);ret=(ret+mul(ret,Pow(m,n/2)))%mod;if(n&1)ret=(ret+mul(Pow(m,(n-1)),t))%mod;returnret;}intmain(){cin>>mod>>m>>c>>x>>n>>mod1;ull ans=Pow(m,n);ans=mul(ans,x);ans=(ans+Sum(n,c))%mod;cout<<ans%mod1;return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

http://www.gsyq.cn/news/98550.html

相关文章:

  • 【3D图像技术分析与实现】Apple Vision Pro三维成像技术栈深度解析
  • 树的初阶相关知识(上)
  • 基于springboot和vue的大学生课程排课管理系统设计_2ux3bmwb(java毕业设计项目源码)
  • WHERE和HAVING子句的使用场景有何不同?
  • 质量管理QMS软件系统:全模块构建卓越质量生态,数据驱动价值升级——全星质量管理QMS软件系统应用解析
  • 混沌这玩意儿在优化算法里真是万金油。今天咱们拿灰狼算法开刀,手把手给它装10种不同的混沌引擎。先上硬货——代码仓库里直接塞个混沌生成器
  • 基于TMS320F28335芯片的BUCK双闭环PI DSP代码
  • 量子软件测试:我们准备好了吗?
  • 超声相控阵全聚焦算法 Comsol超声全矩阵仿真模型(仿真模型可以获得全矩阵数据)
  • 17、Debian系统管理基础与实用工具介绍
  • *SPOOLing 技术(假脱机技术)** - 全称:Simultaneous Peripheral Operations On-Line(外部设备同时联机操作)
  • 在虚拟内存管理中,页面置换算法用于决定当物理内存满时,应将哪个页面换出
  • 19、Debian 系统初始化与自动进程管理全解析
  • 终于有人把大模型讲明白了:LLM 从入门到精通全解析
  • 永生数字系统:与之配套的测试哲学
  • asgiref终极指南:高效解决Python异步通信难题
  • Refine Next.js Turbopack 兼容性实战手记:从构建冲突到性能优化的完整指南
  • 22、Linux系统:备份、安装与管理全攻略
  • 2025年市场上有实力的下水道疏通公司推荐,评价高的下水道疏通哪家强永邦环卫显著提升服务 - 品牌推荐师
  • [Web自动化] HTML表格标签
  • 20251214 之所思 - 人生如梦
  • 好写作AI“新手友好模式”:如何让学术小白自信写出第一篇论文?
  • 本研究基于分形纤维丛统一场论,构建了黑洞时空的几何模型,揭示了奇点消解、霍金辐射修正及信息守恒的新机制。该模型的优势在于将宏观时空的广义相对论效应与微观量子的分形特性实现了有机融合。
  • DeepSeek-Prover-V2:重新定义AI数学推理的黄金标准
  • CSS 布局全指南:从基础到进阶,掌握前端页面排版核心
  • 实力优选!北京 / 天津商场商业美陈活动策划设计制作公司清单
  • GitHub图片管理终极指南:从概念到实践
  • 如何快速定位某个域名(如 deepskai.cn)对应的部署配置与代码目录(CentOS 示例)
  • 缩短启动时间的定制支持成为采用关键——持续选用Silex希来科无线模块逾十年~
  • MLflow跨国团队协作实战:打破语言壁垒的完整解决方案