ABC D 求调
  • 板块学术版
  • 楼主Qiu101029
  • 当前回复6
  • 已保存回复6
  • 发布时间2024/12/7 21:50
  • 上次更新2024/12/8 09:38:41
查看原帖
ABC D 求调
1200904
Qiu101029楼主2024/12/7 21:50
#include<cstdio>
using namespace std;
long long p[80000];bool st[1000005];int cnt,ans;
int main(){
	long long n;scanf("%lld",&n);
	for(int i=2;i<=1000000;i++){
		if(!st[i]) p[cnt++]=i;
		for(int j=0;i*p[j]<=1000000;j++){
			st[i*p[j]]=true;
			if(i%p[j]==0) break;
		}
	}
	for(int i=0;;i++){
		if(p[i]*p[i]*p[i]*p[i]*p[i]*p[i]*p[i]*p[i]<=n) ans++;
		else break; 
	}
	for(int i=0;;i++){
		int j=i+1;
		for(;;j++){
			if(p[i]*p[i]*p[j]*p[j]<=n) ans++;
			else break;
		}
		if(j==i+1) break;
	}
	printf("%d",ans);
	return 0;
}

样例没过(4×10124\times10^{12}),多了一点

2024/12/7 21:50
加载中...