已知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);
}
相关推荐
必胜刻4 小时前
复原 IP 地址(回溯算法)
tcp/ip·算法·深度优先
YGGP4 小时前
【Golang】LeetCode 5. 最长回文子串
算法·leetcode
挖矿大亨4 小时前
C++中的赋值运算符重载
开发语言·c++·算法
qq_433554544 小时前
C++区间DP
c++·算法·动态规划
Halo_tjn5 小时前
Java IO流实现文件操作知识点
java·开发语言·windows·算法
历程里程碑5 小时前
滑动窗口解法:无重复字符最长子串
数据结构·c++·算法·leetcode·职场和发展·eclipse·哈希算法
Geoffwo5 小时前
归一化简单案例
算法·语言模型
Felven5 小时前
C. Maximum Median
c语言·开发语言·算法
星火开发设计5 小时前
广度优先搜索(BFS)详解及C++实现
数据结构·c++·算法··bfs·宽度优先·知识
飞天狗1115 小时前
E. Blackslex and Girls
算法