Codeforces Round #579 (Div. 3) C - Common Divisors 【数论】

Codeforces Round #579 (Div. 3) C - Common Divisors 【数论】

题目:http://codeforces.com/contest/1203/problem/C

大致题意:

给你n个数字,问你他们的共同公约数的种数。

思路:

找出最大公约数的因子数即可。

代码部分:

我怀疑CF是针对我,这两份代码几乎一样,但不知道为什么第二份代码就是TLE。眼睛都快看瞎了都没找出不一样来。
好了,感谢@皓洲大佬,第二份代码 TLE 的问题在于最后的那个循环中,i 不能开成 int,会爆int的,因为i可能会到达 gd 的数量级。改成 long long 就解决了。

第一份代码:

#include<bits/stdc++.h>
using namespace std;

#define ll long long
//ll gcd(ll a,ll b)
//{
//	while(b^=a^=b^=a%=b);
//	return a;
//}
ll a[400015];
int main()
{
	int n;
	scanf("%d",&n);
	for(int i=0;i<n;i++)
		scanf("%lld",&a[i]);
		
	ll minnum = a[0];
	for(int i=1;i<n;i++)
	{
		if(__gcd(minnum,a[i]) < minnum)
			minnum = __gcd(minnum,a[i]);
		if(minnum == 1)
			break;
	}
	if(minnum == 1)
		printf("1\n");
	else
	{
		ll ans = 0;
		for(ll i=1;i*i<=minnum;i++)
		{
			if(minnum==i*i)
				ans++;
			else if(minnum%i==0)
				ans+=2;
		}
		printf("%lld\n",ans);
	}	
	return 0;
}

第二份代码:

#include<bits/stdc++.h>
using namespace std;
#define ll long long
//ll mygcd(ll a, ll b) {
//	while(b^=a^=b^=a%=b);
//	return a;
//}
ll num[400015];

int main() {
	int n;
	scanf("%d",&n);
	for(int i = 0; i < n; i++)
		scanf("%lld",&num[i]);
	
	ll gd = num[0];
	for(int i = 1; i < n; i++) {
		ll temp = __gcd(gd, num[i]);
		if(temp < gd)
			gd = temp;
		if(gd == 1)
			break;
	}
	if(gd == 1) {
		printf("1\n");
	}
	else {
		ll ans = 0;
		//这个位置!!!!!!!!!!必须要用long long
		//我就不改了,把这个错误放在这里提醒自己。
		for(int i = 1; i*i <= gd; i++) {
			if(gd == i*i)
				ans++;
			else if((gd % i) == 0)
				ans+=2;
		}
		printf("%lld\n",ans);
	}
	return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断路器保护灵敏度校验整改及剩余电流监测试点应用站用交流系统断

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值