【洛谷 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;
}
相关推荐
熊猫钓鱼>_>12 小时前
深入理解Java堆栈:从原理到面试实战
java·开发语言·面试·职场和发展·面向对象·堆栈·oop
孞㐑¥12 小时前
算法—哈希表
开发语言·c++·经验分享·笔记·算法
近津薪荼13 小时前
递归专题(2)——合并链表
c++·学习·算法·链表
maplewen.13 小时前
C++11 std::function
开发语言·c++
jiayong2313 小时前
Vue2 与 Vue3 生态系统及工程化对比 - 面试宝典
vue.js·面试·职场和发展
水饺编程13 小时前
第4章,[标签 Win32] :文本尺寸的度量
c语言·c++·windows·visual studio
蒹葭玉树13 小时前
【C++上岸】C++常见面试题目--操作系统篇(第二十九期)
java·c++·面试
学历真的很重要13 小时前
【系统架构师】第一章 计算机系统基础知识(详解版)
学习·职场和发展·系统架构·系统架构师
浅念-13 小时前
C语言——自定义类型:结构体、联合体、枚举
c语言·开发语言·数据结构·c++·笔记·学习·html
仰泳的熊猫13 小时前
题目1433:蓝桥杯2013年第四届真题-危险系数
数据结构·c++·算法·蓝桥杯·深度优先·图论