WZ℡T 2018-11-28 13:35 采纳率: 50%
浏览 403
已采纳

大佬们,怎么把这个程序算非常大的数时 计算用的时间更短 ?

#include
int main()
{
int n,i;//n存放输入的数值,i控制循环
long j;//j存放每次循环的累加值
j=0;
scanf("%d",&n);
if(1<=n<=1000000000)//n的取值范围
{
for(i=1; i<=n; i++)
{
j=j+i;
}
printf("%I64d",j);
}
return 0;
}

  • 写回答

3条回答 默认 最新

  • threenewbee 2018-11-28 14:29
    关注

    用公式计算

     j = (1+n)*n/2
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 matlab有关常微分方程的问题求解决
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?
  • ¥100 求三轴之间相互配合画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable