【洛谷 P8753】[蓝桥杯 2021 省 AB2] 小平方 题解(数学+暴力枚举)


思路

首先,定义一个长整型变量ans来存储满足条件的数的数量,初始化为0。然后,从标准输入读取一个整数n

计算n的一半,存储在双精度浮点变量mid中。这是因为我们要找的是平方后除以n的余数小于n的一半的数。

接下来,使用一个for循环,从1遍历到n。在每次迭代中,计算i的平方对n取余的结果,检查这个结果是否小于mid。如果小于mid,则ans加1。这是因为我们要计数的是平方后除以n的余数小于n的一半的数的数量。

最后,将ans输出到标准输出。这就是满足条件的数的数量。

注意:在计算n的一半时要使用(double)n / 2,以确保结果是一个浮点数,避免整数除法可能导致的精度丢失。


AC代码

cpp 复制代码
#include <iostream>
#define AUTHOR "HEX9CF"
using namespace std;
using ll = long long;

int main() {
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);

	ll ans = 0;
	int n;
	cin >> n;
	double mid = (double)n / 2;
	for (int i = 1; i < n; i++) {
		if (i * i % n < mid) {
			ans++;
		}
	}
	cout << ans << endl;
	return 0;
}
相关推荐
WiChP2 小时前
【V0.1B9】从零开始的2D游戏引擎开发之路
c++·游戏引擎
Peter·Pan爱编程3 小时前
从 struct 到 class:封装与访问控制的真正意义
c++
Hical613 小时前
C++26 反射落地实战
c++·开源
计算机安禾3 小时前
【c++面向对象编程】第22篇:输入输出运算符重载:<< 与 >> 的友元实现
java·前端·c++
北山有鸟3 小时前
解决香橙派没有适配ov13855的3A算法
linux·c++·相机·isp
故事和你914 小时前
洛谷-【图论2-1】树4
开发语言·数据结构·c++·算法·动态规划·图论
故事和你914 小时前
洛谷-【图论2-1】树1
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
不会C语言的男孩4 小时前
C++ SLTL编程
java·开发语言·c++
码农-阿杰5 小时前
Java 线程等待唤醒机制深度解析:synchronized、ReentrantLock、LockSupport 底层实现对比
java·开发语言·c++
十五年专注C++开发5 小时前
TypePerf:Windows 命令行性能计数器工具(CPU利用率、内存利用率、GPU利用率等)
c++·windows·typeperf