3103: 【基础】既生瑜,何生亮!

题目描述

某数的平方是7位数,且这7个数字不相同,如1267^2=1605289。 编写程序,输入x,y(1000≤x≤y≤9999)在x~y的范围内找出所有符合条件的数并打印出来。

输入

一行,一个整数。

输出

若干行,每行一个符合条件的数。

样例输入 复制

txt 复制代码
1000 1025

样例输出 复制

txt 复制代码
1017
1023
1024
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
bool check(int val)
{
	int number_count[10] = {0};
	int len = 0; //长度
	while (val)
	{
		number_count[val % 10]++; //取出每一位
		val /= 10;
		len++; //长度增加
	}
	if (len != 7) return false;
	for (int i = 0; i <= 9; i++)
	{
		if (number_count[i] > 1) //重复了
			return false;
	}
	return true;
}
int main()
{
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	cout.tie(nullptr); 
	int x, y;
	cin >> x >> y;
	// 计算平方的最小和最大范围
	int min_i = ceil(sqrt(1000000)); // 七位数的最小平方根
	int max_i = floor(sqrt(9999999)); // 七位数的最大平方根
	// 限制范围
	x = max(x, min_i);
	y = min(y, max_i);
	for (int i = x; i <= y; i++)
	{
		if (check(i * i)) //平方
			cout << i << '\n';
	}
	return 0;
}
相关推荐
尘诞辰16 分钟前
【C语言】数据在内存中的储存
c语言·开发语言·数据结构·c++
无敌最俊朗@19 分钟前
STL-关联容器(面试复习4)
开发语言·c++
无限进步_26 分钟前
【C语言】栈(Stack)数据结构的实现与应用
c语言·开发语言·数据结构·c++·后端·visual studio
闻缺陷则喜何志丹26 分钟前
【计算几何 SAT轴】P6732 「Wdsr-2」方分|普及+
c++·数学·计算几何·sat轴·凸多边形分离
embrace9926 分钟前
【C语言学习】预处理详解
java·c语言·开发语言·数据结构·c++·学习·算法
拼好饭和她皆失28 分钟前
《二分答案算法精讲:从原理到实战(上篇)》
c++·算法
helloworddm34 分钟前
C++与C#交互 回调封装为await
c++·c#·交互
应用市场37 分钟前
TCP网络连接断开检测机制详解——C++实现网络连通性判断与断线类型识别
网络·c++·tcp/ip
雾岛听蓝39 分钟前
C/C++内存管理
c语言·c++
AuroraWanderll42 分钟前
类和对象(三)-默认成员函数详解与运算符重载
c语言·开发语言·数据结构·c++·算法