蓝桥杯 第十五届 研究生组 B题 召唤数学精灵

问题描述:

数学家们发现了两种用于召唤强大的数学精灵的仪式,这两种仪式分别被称为累加法仪式 A(n) 和累乘法仪式 B(n)。累加法仪式 A(n) 是将从 1 到 n 的所有数字进行累加求和,即:A(n)=1+2+⋯+n累乘法仪式 B(n) 则是将从 1 到 n 的所有数字进行累乘求积,即:B(n)=1×2×⋯×n据说,当某个数字 i 满足 A(i)−B(i) 能被 100 整除时,数学精灵就会被召唤出来。现在,请你寻找在 1 到 2024041331404202 之间有多少个数字 i,能够成功召唤出强大的数学精灵。

答案提交:

这是一道结果填空题,你只需要算出结果后提交即可。本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

解题思路:

由于查找的数过多,所以一定不是使用的for循环来解题,而是从中查找规律,所以先遍历前1000个数字,发现除前两个符合要求的数字,其余的数字%200都应该是0、24、175、199,所以可以直接计算出2024041331404202中一共有多少个200的组,并且判断2024041331404202%200的数字应该处于哪个区间(以0、24、175、199来划分区间),最终就可以得到可以召唤数学精灵的个数。

注意:

①可以召唤精灵的个数应该为long long类型,其超出了int型可以表示的范围;

②第一个200的组,其有5个符合要求的数字,所以最后应该要+1。

代码:

找规律代码:

cpp 复制代码
//找规律
int A = 0, B = 1;    //记录A(i)%100和B(i)%100
cout << "i" << '\t' << "A" << '\t' << "B" << '\t' << "number" << endl;
for (int i = 1;i < 1000;i++)
{
	A = (A + i) % 100;
	B = (B * i) % 100;	if (A == B)   //为想要的i
	{
		number++;
		cout << i << '\t' << A << '\t' << B << '\t' << number << endl;
	}
}

规律输出:

cpp 复制代码
i       A       B       number
1       1       1       1
3       6       6       2
24      0       0       3
175     0       0       4
199     0       0       5
200     0       0       6
224     0       0       7
375     0       0       8
399     0       0       9
400     0       0       10
424     0       0       11
575     0       0       12
599     0       0       13
600     0       0       14
624     0       0       15
775     0       0       16
799     0       0       17
800     0       0       18
824     0       0       19
975     0       0       20
999     0       0       21

main函数:

cpp 复制代码
#include <iostream>
using namespace std;
int main()
{
	请在此输入您的代码
	long long number = 0;    //记录i的个数
	number = 2024041331404202 / 200 * 4 + 1;    //可以被200整除的部分,其中+1是指前199个数中,有1、3、24、175、199五个符合要求的数字,比后面每200个多一个,所以要+1
	int left = 2024041331404202 % 200;
	if (left < 24)
	{
		number++;
	}
	else if (left < 175)
	{
		number += 2;
	}
	else if (left < 199)
	{
		number += 3;
	}
	else
	{
		number += 4;
	}
	cout << number;

	return 0;
}

运行结果:

cpp 复制代码
40480826628086
相关推荐
小的~~6 小时前
算法题:只出现一次的数字
数据结构·算法
灵智实验室6 小时前
PX4状态估计技术EKF2详解(六):EKF2 磁力计融合——从航向修正到 3D 姿态约束
算法·无人机·px 4
hhcgchpspk6 小时前
easyx按键游戏
c++·stm32·单片机·游戏·easyx
JieE2126 小时前
手把手带你用虚拟头节点实现单链表,搞定所有边界问题
javascript·算法
郝学胜-神的一滴6 小时前
Qt 高级开发 011: 跨线程信号槽实战
开发语言·c++·qt·程序人生·开源软件·用户界面
学困昇7 小时前
Linux 动静态库制作与原理:从 .a、.so 到 ELF 加载一次讲透
linux·运维·服务器·c语言·开发语言·c++·人工智能
basketball6167 小时前
C++面试考点 头文件与实现文件形式
开发语言·c++
历程里程碑7 小时前
56 . 高效ET非阻塞IO服务器设计指南
java·运维·服务器·开发语言·数据结构·c++·排序算法
搞科研的小刘选手7 小时前
【大连市计算机学会主办】第三届图像处理、智能控制与计算机工程国际学术会议(IPICE 2026)
图像处理·人工智能·深度学习·算法·计算机·数据挖掘·智能控制
人月神话-Lee7 小时前
【图像处理】高斯模糊——最优雅的模糊算法
图像处理·人工智能·算法·ios·ai编程·swift