本文介绍了我不断收到错误消息“超过了时间限制".在C程序中.如何提高代码效率?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我不知道如何用高级概念解决问题,所以我只使用循环来解决它.
I don't know how to solve the problem with advanced concepts so I solved it by using just loops.
此问题的时间限制为6.00s
The time limit to this problem is 6.00s
#include <stdio.h>
int main(void)
{
int a[1],b[1],j,i,test,k,flag;
scanf("%d",&test);
for(i=1;i<=test;i++)
{
for(k=0;k<1;k++)
{
scanf("%d %d",&a[k],&b[k]);
}
for(j=a[0];j<=b[0];++j)
{
flag=0;
for(k=2;k<j;++k)
{
if(j%k==0)
{
flag=1;
break;
}
}
if(flag==0)
{
printf("\n%d",j);
}
}
}
return 0;
}
推荐答案
可改善性能的建议对.
-
您无需一路检查到
b [0]
.您最多只需要检查sqrt(b [0])
.
更新循环,以便仅检查奇数而不检查所有数字.
Update the loop so that you check only odd numbers not all numbers.
替换
for(j=a[0];j<=b[0];++j)
{
由
int stop = sqrt(b[0]);
// Start with an odd number and keep incrementing j by 2 to keep it that way
for(j= (a[0]/2)*2+1; j <= stop; j +=2 )
{
这篇关于我不断收到错误消息“超过了时间限制".在C程序中.如何提高代码效率?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!