这个题目有点意思~
题目要求| i-j |>1 && n%| i-j |==0 所以|i-j|是n的因数。
结论:
1.若n本身为质数,则一共有n种颜色。
2.只有一个质因子(=m),则m种颜色。
3.若n质因子个数>=2,则所有格子都会有相同颜色,即结果为1。
情况1、2很容易得出,画一下图很容易看出来。这里讨论第3种情况
其实推断一下就很容易发现,最多的颜色数<=n的最小质因子。
好比如15,因数有1,3,5,15。
则每隔5个就有相同的颜色,即:
格子1 6 11,2 7 12、3 8 13、4 9 14、5 10 15分别相同颜色,可以发现格子第1-5号可以直接表示了这5种颜色(因为后面的颜色分别和1-5中的一个颜色相同。)
又每隔3隔就有相同颜色,同理,格子1-3号表示了这3种颜色。
所以,初步推断,n个格子,最多颜色数<=最小质因子。
为什么不是直接=最小质因子呢?
令:m=“n的最小质因子”。
用n=15这个例子,从1~15分为每连续3个一组,初步推断!!可知每组中的3个颜色两两不相同。接着往下一个质因子去推,以1为起点,每+5一次其实就相当于在第一组的1~3号中移动成对应的位置(其实相当于循环),因为若+3则移动到4,相当于1号位置(因为1和4的颜色相同),而+5即多移动了2个位置,所以第一次+5对应到了3号位置,第2次+5可对应到2号位置,第3次+5可对应到1号位置…可看出其实每一次+5,相当于在一个环形圈里移动位置,而只需移动m-1次即可遍历完所有的格子,得出结论——这些格子颜色都相同。
而格子一共只有n个,为什么就一定可以移动m-1次呢?
∵ 比如n=15=3*5,对于这两个质因子,假设为x1,x2 则x1*x2=n 若x1=3,x2=5,所以一共有x2个x1,而对于从1号位置开始,每次+5 得出的格子位置为1+x2*t (t=1,2,3...)
∴1+5*t所以max(t)=x1-1,刚好可以遍历完所有格子。
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll solve(ll n){
ll cnt=0;
ll nn=n;
for(ll i=2;i*i<=n;i++){
if(n%i==0){
cnt++;//记录质因子个数
while(n%i==0){
n/=i;
}
if(n!=1)
return 1;//说明>=2个质因子
if(n==1)//说明只有一个质因子
return i; //返回最小质因子
}
}
return nn;//本身是质数
}
int main() {
ll n;
scanf("%I64d",&n);
printf("%I64d",solve(n));
return 0;
}