「C++」简单模拟
这是一个公式:
\]
根据大家的数学经验可以知道这是一个计算斐波那契数列的公式,那么假设我们不知道这是一个斐波纳契数列的公式,只知道他是一个简单的数学计算公式,该怎么求这个公式的值呢?答案就是需要使用模拟!而这篇博文,我们就来讨论一些简单的模拟题目,再教给大家一些做模拟题的方法。
Q1:使用公式求斐波那契数列第n项值
这是一个非常简单的模拟,可以直接使用C++头文件cmath中的库函数完成,这里我们可以看到题目中有两个比较难搞的东西,一个是:$$\sqrt{5} $$而另一个就是$${m}^{n} (m指的是前面的算式,分别是\left(\frac{1+\sqrt{5}}{2}\right)和\left(\frac{1-\sqrt{5}}{2}\right))$$
根号可以使用sqrt函数,而m的n次方可以使用pow函数(或者位运算),注意,这两个函数的返回值都是double类型的,所以最好使用double类型存储,而且pow函数会有精度误差,所以一定要谨慎使用。
接下来给大家看一下初步的代码:
#include<bits/stdc++.h>
using namespace std;
// 该函数用于计算斐波那契数列的第n项
double fibonacci(int n) {
// 特判
if(n <= 0) {
return 0;
}
// 模拟
double phi = (1 + sqrt(5)) / 2;
double psi = (1 - sqrt(5)) / 2;
double numerator = pow(phi, n) - pow(psi, n);
double denominator = sqrt(5);
return numerator / denominator;
}
int main() {
int n;
cin >> n; // 读入
// 设置输出精度,以便更好地显示浮点数结果
cout << fixed << setprecision(2); // 这里我们输出两位小数
if (n >= 1) {
double res = fibonacci(n);
cout << "Fibonacci number at index " << n << " is: " << res << endl;
} else {
cout << "No answer" << endl;
}
return 0;
}
输出一下,完全正确!
这里我们定义了一个函数fibonacci,该函数用于求斐波那契数列的第n项,在函数里面,我们定义了四个变量:phi、psi、numerator和denominator。
phi求的是分数分子的左边部分(减号前的部分);
psi求的是分数分子的右半部分(减号后的部分);
numerator顾名思义是分子;
denominator顾名思义就是分母。
最后的返回值就是分数值(也就是分子除以分母)
接下来我们来看一看下一个问题。
Q2:[NOIP2003 普及组] 乒乓球
题目背景
国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。其中 \(11\) 分制改革引起了很大的争议,有一部分球员因为无法适应新规则只能选择退役。华华就是其中一位,他退役之后走上了乒乓球研究工作,意图弄明白 \(11\) 分制和 \(21\) 分制对选手的不同影响。在开展他的研究之前,他首先需要对他多年比赛的统计数据进行一些分析,所以需要你的帮忙。
题目描述
华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在 \(11\) 分制和 \(21\) 分制下,双方的比赛结果(截至记录末尾)。
比如现在有这么一份记录,(其中 \(\texttt W\) 表示华华获得一分,\(\texttt L\) 表示华华对手获得一分):
\(\texttt{WWWWWWWWWWWWWWWWWWWWWWLW}\)
在 \(11\) 分制下,此时比赛的结果是华华第一局 \(11\) 比 \(0\) 获胜,第二局 \(11\) 比 \(0\) 获胜,正在进行第三局,当前比分 \(1\) 比 \(1\)。而在 \(21\) 分制下,此时比赛结果是华华第一局 \(21\) 比 \(0\) 获胜,正在进行第二局,比分 \(2\) 比 \(1\)。如果一局比赛刚开始,则此时比分为 \(0\) 比 \(0\)。直到分差大于或者等于 \(2\),才一局结束。
你的程序就是要对于一系列比赛信息的输入(\(\texttt{WL}\) 形式),输出正确的结果。
输入格式
每个输入文件包含若干行字符串,字符串有大写的 \(\texttt W\) 、 \(\texttt L\) 和 \(\texttt E\) 组成。其中 \(\texttt E\) 表示比赛信息结束,程序应该忽略 \(\texttt E\) 之后的所有内容。
输出格式
输出由两部分组成,每部分有若干行,每一行对应一局比赛的比分(按比赛信息输入顺序)。其中第一部分是 \(11\) 分制下的结果,第二部分是 \(21\) 分制下的结果,两部分之间由一个空行分隔。
样例 #1
样例输入 #1
WWWWWWWWWWWWWWWWWWWW
WWLWE
样例输出 #1
11:0
11:0
1:1
21:0
2:1
提示
每行至多 \(25\) 个字母,最多有 \(2500\) 行。
(注:事实上有一个测试点有 \(2501\) 行数据。)
【题目来源】
NOIP 2003 普及组第一题
分析
这是一道很经典的签到模拟题,我们可以直接根据题意模拟:
#include<bits/stdc++.h>
using namespace std;
int win[114514];
int w, l;
int main() {
char s;
for(int i = 1; cin >> s && s != 'E'; ++ i) {
if(s == 'W') win[i] = 1;
else win[i] = 2;
}
for(int i = 1; ; ++ i) {
if(win[i] == 1) ++ w;
if(win[i] == 2) ++ l;
if(win[i] == 0) {
cout << w << ":" << l << endl << endl;
break;
}
if(w - l >= 2 || l - w >= 2)
if(w >= 11 || l >= 11) {
cout << w << ":" << l << endl;
w = 0;
l = 0;
}
}
w = 0;
l = 0;
for(int i = 1; ; ++ i) {
if(win[i] == 1) ++ w;
if(win[i] == 2) ++ l;
if(win[i] == 0) {
cout << w << ":" << l;
break;
}
if(w - l >= 2 || l - w >= 2)
if(w >= 21 || l >= 21) {
cout << w << ":" << l << endl;
w = 0;
l = 0;
}
}
return 0;
}
首先一定要开数组存储胜负次数,因为你不仅要存胜负的场数,还要存胜负的顺序,以此来排分数。其次分数差要大于2,这是因为正规乒乓球比赛,不仅分数要大于11(或21),两者分数相差也要大于2。如果比赛分数达到11-10,比赛会继续。直到一个人比另外一个人多两分。(如13-11)21分制同理,这里不再过多阐述。
其实这两道题目的模拟算是C++当中最简单的,接下来,我会再发表几篇文章用以阐述复杂的模拟算法。
「C++」简单模拟的更多相关文章
- 「NOWCODER」CSP-S模拟赛第3场
「NOWCODER」CSP模拟赛第3场 T1 货物收集 题目 考场思路即正解 T2 货物分组 题目 考场思路 题解 60pts 算法:一维 DP 100pts 算法:一维 DP ?线段树 + 单调栈 ...
- 「CQOI2006」简单题 线段树
「CQOI2006」简单题 线段树 水.区间修改,单点查询.用线段树维护区间\([L,R]\)内的所有\(1\)的个数,懒标记表示为当前区间是否需要反转(相对于区间当前状态),下方标记时懒标记取反即可 ...
- 「SOL」行列式 (模拟赛)
1. 题面 有一个大小为 \(n\) (\(n\le10^6\))的方阵 \(A\),给定 \(d_1,d_2,d_3,\dots,d_n\),\((p_2,b_2,c_2),(p_3,b_3,c_3 ...
- 「数据结构」:模拟指针(simulated pointer)
模拟指针,也就是清华严老师<数据结构-C语言描述>中的静态链表,静态链表的引用是使用一段连续的存储区还模拟指针的功能,可以有效的利用一段连续内存进行一定范围内可变的子链表的空间分配,此数据 ...
- 「题解」NOIP模拟测试题解乱写I(29-31)
NOIP模拟29(B) T1爬山 简单题,赛时找到了$O(1)$查询的规律于是切了. 从倍增LCA那里借鉴了一点东西:先将a.b抬到同一高度,然后再一起往上爬.所用的步数$×2$就是了. 抬升到同一高 ...
- 「考试」联赛模拟36-39,noip晚间小测2-3
36.1 party(CF623D) 很是鸡贼的一道题 首先要明确一点,抓人是有策略,而不是随机的,可以认为等同于按一个给定的顺序猜人,那么这时猜中的概率就只是抓住这个人的概率了 对于每一次猜测,因为 ...
- 「考试」noip模拟9,11,13
9.1 辣鸡 可以把答案分成 每个矩形内部连线 和 矩形之间的连线 两部分 前半部分即为\(2(w-1)(h-1)\),后半部分可以模拟求(就是讨论四种相邻的情况) 如果\(n^2\)选择暴力模拟是有 ...
- 「PHP」简单工厂模式
引言 所属:创建型模式,常用设计模式之一 工厂模式分为:简单工厂模式.工厂方法模式.静态工厂模式.抽象工厂模式. 下面为简单工厂模式. 参考资料: <大话设计模式>程杰 模式概 ...
- 「题解」NOIP模拟测试题解乱写II(36)
毕竟考得太频繁了于是不可能每次考试都写题解.(我解释个什么劲啊又没有人看) 甚至有的题目都没有改掉.跑过来写题解一方面是总结,另一方面也是放松了. NOIP模拟测试36 T1字符 这题我完全懵逼了.就 ...
- 「 题解」NOIP2021模拟赛(2021-07-19)
小兔的话 欢迎大家在评论区留言哦~ D - 矩阵 简单题意 一个 \(i * i\) 的 \(01\) 矩阵,若满足 每一行 和 每一列 都满足 恰好 有 \(2\) 个位置是 \(1\) 时,称为 ...
随机推荐
- 技术干货 | 阿里云数据库PostgreSQL 13大版本揭秘
简介: 阿里云RDS PostgreSQL是一款兼容开源PostgreSQL的全托管云数据库产品,自2015年首次发布以来,根据用户需求不断升级迭代,已支持9.4.10.11.12等多个版本,覆盖了高 ...
- Quick BI产品核心功能大图(四):Quick引擎加速--十亿数据亚秒级分析
简介: 随着数字化进程的深入,数据应用的价值被越来越多的企业所重视.基于数据进行决策分析是应用价值体现的重要场景,不同行业和体量的公司广泛依赖BI产品制作报表.仪表板和数据门户,以此进行决策分析. ...
- 基于MaxCompute+开放搜索的电商、零售行业搜索开发实践
简介: 搜索一直是电商行业流量来源的核心入口之一,如何搭建电商行业搜索并提升搜索效果,一直是电商行业开发者努力攻克的难题.基于传统数据库或开源引擎虽然能够搭建基础搜索服务,但随着商品数据的增多和业务 ...
- MDK在头文件中使用预编译器时,#ifdef 无效的问题
问题:在头文件中使用预编译时,会出现无效的现象 在a.h文件中定义了宏AA_TEST,如下所示 #ifndef __A_H #define __A_H #define AA_TEST #endif 在 ...
- pde复习笔记 第一章 波动方程 第三节 分离变量法
教材 谷超豪<数学物理方程>第四版,虽然我们老师用的第三版,但是除了页码对不上,习题多了一点,也似乎没有多少区别. 打算开个新栏专门总结一下pde的各种计算问题,在图书馆算的手麻了,但是习 ...
- ansible(15)--ansible的mount模块
1. mount模块 功能:管理被控端设备挂载: 主要参数如下: 参数 说明 src 本地或远程设备的路径 path 设备挂载至本地的路径 fstype 挂载的文件系统类型,xfs.nfs... op ...
- angular自定义属性指令
在angular中有三种类型的指令: 组件–拥有模板的指令: 结构性指令–通过添加和移除DOM元素改变DOM布局的指令; 属性型指令–改变元素.组件或其他指令的外观和行为的指令: 组件是这三种指令中最 ...
- nginx 常见配置案例参考(优化)
在NGINX中,可以通过配置文件和特定的指令来实现权限控制.以下是一些常见的权限控制方法: 使用deny指令: 在NGINX配置文件中,可以使用deny指令来拒绝特定IP地址或IP地址范围的访问.可以 ...
- 用友u8 使用 api资源管理器新增单据的一些方法
一般都使用传xml对象的方式.这种方式方便在只需传入正确的视图就行了.但是如果字段不全,或者字段的数据类型与api要求的不服,会报些莫名其妙的错误,比如这些: 项目大类0不存在项目大类0不存在货位不合 ...
- python 实现限流
固定窗口 固定窗口就是记录一个固定的时间窗口内的操作次数,操作次数超过阈值则进行限流. def fix_window_limit(redis_obj, period, max_count): &quo ...