已知n找最小正整数x使n*x为一个平方数

已知正整数n,求最小的正整数x,使得n*x是一个平方数。例如n=12,则最小的x是3,n*x为36是一个平方数。

输入

仅一个正整数n,n < 231

输出

输出最小的正整数x。

样例输入 Copy
复制代码
4
样例输出 Copy
复制代码
1
cs 复制代码
#include <stdio.h>
#include<math.h>
int main(void)
{
	int n;
	scanf("%d",&n);
	int x;
	for(int i=sqrt(n);i>0;i--)
	{
		if(n%(i*i)==0)
		{
			x=n/(i*i);
			break;
		}
	}
	printf("%d",x);
}
相关推荐
ULTRA??6 分钟前
QT向量类实现GJK碰撞检测算法3d版本
c++·qt·算法
仰泳的熊猫11 分钟前
1092 To Buy or Not to Buy
数据结构·c++·算法·pat考试
罗湖老棍子17 分钟前
【深基16.例3】二叉树深度(洛谷P4913)
数据结构·算法·二叉树
Charlo21 分钟前
Open-AutoGLM Windows 安装部署教程
算法·设计模式·github
君义_noip31 分钟前
信息学奥赛一本通 4017:【GESP2309三级】小杨的储蓄 | 洛谷 B3867 [GESP202309 三级] 小杨的储蓄
c++·算法·gesp·信息学奥赛
高山上有一只小老虎1 小时前
判断是否为数独数组
java·算法
宝贝儿好1 小时前
【强化学习】第二章:老虎机问题、ε-greedy算法、指数移动平均
人工智能·python·算法
CoovallyAIHub1 小时前
超越深度学习:量子优化如何通过算法与硬件重塑AI
深度学习·算法·计算机视觉
mit6.8241 小时前
模拟|str_dp
算法