方法有很多,具体分析如下:
1、最直观的方法。
循环遍历100以内所有整数,逐一判断是否可以被3整除或者被5整除,如果可以,则累加。
代码如下:
#include
int main()
{
int s=0;
int n;
for(n = 1; n < 100; n ++)//遍历
if(n%3==0 || n %5 == 0)//符合条件
s+=n;//累加。
printf("%d\n",s);//输出结果。
return 0;
}
2、最快捷的方法。
根据数学规则,可以被3整除的为一个等差数列,可以被5整除的也是一个等差数列。
可以被3或5整除的和,就是所有被3整除的数和,加上所有被5整除的数之和,减去同时被3和5整除的数之和,即减去被15整除的数之和。
其中,被3整除的为3,6,9...,99共计33个。 能被5整除的为5,10,...95共计19个。能被15整除的为15,30,...90共计6个。
于是得到如下程序:
#include
int main()
{
int a=(3+99)*33/2;//被3整除之和。
int b=(5+95)*19/2;//被5整除之和。
int c=(15+90)*6/2;//被15整除之和。
int s=a+b-c;//计算结果.
printf("%d\n", s);//输出。
return 0;
}
3、对比。
前一种方式,适合C语言练习,使用到循环,比较,模除,输出等多个知识点。
后一种方式,效率更高,适合实际编程使用。
思路是用循环:
#include
int main(){
int sum=0, i;
for(i=1; i<100; ++i)
if(i%3==0||i%5==0) sum+=i;
printf("%d\n",sum);
return 0;
}
#include "stdio.h"
int main(void){
__int64 i,p;
for(p=1,i=3;i<30;p*=i,i+=3);
printf("The result is %I64d\n",p);
return 0;
}