1.什么是数值处理问题?主要针对数据进行各种处理的相关问题,如:求任一整数的位数;求任一整数各位数字之和;将任一整数各位数字输出;求两个整数的最大公约数或最小公倍数;求整数因子或完数。
2.怎么求解数值处理问题?用循环。
例题1:求任一整数各位数字之和。
#include <stdio.h>
int main()
{ long n;/*定义n为长整型*/
int m,s=0;
scanf("%ld",&n);
while(n!=0)
{ m=n%10;
n=n/10;
s=s+m;
}
printf("s=%6d\n",s);
return 0;
}
2.分解任一整数n因子并输出
分析:整数不清楚是几位,故循环次数不确定;1-n之间的数字m都有可能是n的因子,但n能被m整除,m才是其因子;m有可能有多个而且有可能相等;到整数n为1,则停止求解。代码如下:
#include <stdio.h>
int main()
{ int n,m=2;
scanf("%d",&n);
printf("%d=1",n);
while(n>1)
{ while(n%m==0)
{ printf("*%d",m);
n/=m; }
m++;
}
return 0;
}