public static double factorial(int n) //求阶乘函数
{
if(n==0) return 1;
else return n* factorial(n-1);
}
public static void main(String[] args) {
System.out.println(factorial(170));//test:能打印出来,170之后便不能打印了
/*1、使用while循环计算1-1000之间能被3和7同时整除的整数之和*/
int count=0;//整数之和
int i=1000;
while(i>0){
if((i%3==0)&&(i%7==0)){
count+=i;
}
i--;
}
System.out.println("1-1000之间能被3和7同时整除的整数之和:"+count);
/*2、使用for循环计算8+88+888+···的前10项之和*/
long mun=0;
for(int j=0;j<10;j++){
mun+=mun+8*(Math.pow(10, j));
//System.out.println(mun); //test
}
System.out.println("8+88+888+···的前10项之和:"+mun);
/* 3、计算1-1/3+1/5-1/7+···的前10000项之和 */
double mun2=0;
for(int n=0;n<10000;n++){
int t=(int)Math.pow(-1, n);
double p=1.0/(2.0*n+1);
mun2+=t*p;
//System.out.println(mun2);//test
}
System.out.println("1-1/3+1/5-1/7+···的前10000项之和:"+mun2);
/*4、计算1+2!+3!+4!+···从第100项到200项之和*/
double f=0;
for(int k=100;k<=200;k++){
f+=factorial(k);
//System.out.println(f);
}
System.out.println("1+2!+3!+4!+···从第100项到200项之和:"+f);
System.out.println("Infinity表示正无穷大,即大于dOUble类型所能表示的最大数值。负无穷大将输出" +
"-Infinity./n实际上,任何计算结果只要超出double类型所能表示的最大数值,就会产生这样的结果。");
}
}