cf#599(div2)C - Tile Painting

题目

这个题目有点意思~

题目要求| 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;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值