题目描述
对于给定的一个数,如果大于10,则取整到最接近的整十数,如果超过了100,则取最接近的整百数,如果超过了1000,则取最接近的整千数,以此类推。
提示:取整方法采用四舍五入法。
输入
输入包含若干个测试用例,第一行为正整数n,接下来n行,每行一个要求取整的整数x(0<=x<=99999999)。
输出
对每个要求取整的整数,用一行输出其取整后的结果。
样例输入 Copy
9
15
14
4
5
99
12345678
44444445
1445
446
样例输出 Copy
20
10
4
5
100
10000000
50000000
2000
500
#include<stdio.h>
#include<string.h>
int main()
{
int n,i,k,m,f,j,t;
scanf("%d",&n);
while(n--)
{
scanf("%d",&m);
if(m>=10)
{
k=m;
j=0;
f=0;
while(k)
{
j++;
t=k%10;
if(k>0&&k<=9)
{
if(k+f>9)
{
k=1;
j++;
break;
}
else
{
k=k+f;
break;
}
}
else if(t+f>=5)
f=1;
else f=0;
//f表示是否需要进位
k/=10;
}
for(i=0; i<j-1; i++)
{
k=k*10;
}
//补零
printf("%d\n",k);
}
//如果输入的数大于等于10就进行操作
else
printf("%d\n",m);
}
return 0;
}