【洛谷 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;
}
相关推荐
小熊Coding5 分钟前
Windows 上安装 mysqlclient 时遇到了编译错误,核心原因是缺少 Microsoft Visual C++ 14.0 或更高版本 的编译环境。
c++·windows·python·microsoft·django·mysqlclient·bug记录
艾莉丝努力练剑7 分钟前
【Linux线程】Linux系统多线程(六):<线程同步与互斥>线程同步(上)
java·linux·运维·服务器·c++·学习·线程
feng_you_ying_li10 分钟前
C++11可变模板参数,包扩展,emplace系列和push系列的区别
前端·c++·算法
tankeven10 分钟前
HJ177 可匹配子段计数
c++·算法
白藏y19 分钟前
【C++】ifstream、ofstream、fstream的基础使用
c++
皮卡蛋炒饭.22 分钟前
Linux进程信号
开发语言·c++
共享家952729 分钟前
C++ 日志类设计
linux·c++·后端
小辉同志35 分钟前
208. 实现 Trie (前缀树)
开发语言·c++·leetcode·图论
John.Lewis38 分钟前
C++加餐课-stack_queue:反向迭代器
数据结构·c++
云栖梦泽38 分钟前
Linux内核与驱动:12.设备树实例分析
linux·c++·单片机