1.编写一个程序,要求用户输入一个两位数,然后按数位的逆序打印出这个数。程序会话应类似下面这样:
Enter a two-digit number: 28
The reversal is: 82
用%d读入两位数,然后分解成两个数字。提示:如果n是整数,那么n%10是个位数,而n
10则是移除个位数后剩下的数。
#include<stdio.h>
int main(void)
{
int num,a,b;
printf("Enter a two_digit number: ");
scanf("%d",&num);
a=num/10,b=num%10;
printf("The reversal is: %d%d",b,a);
return 0;
}
3.扩展上题中的程序使其可以处理3位数。
#include<stdio.h>
int main()
{
int num,a,b,c;
printf("Enter a three_digit number: ");
scanf("%d",&num);
a=num/100,b=(num-100*a)/10,c=num%10;
printf("The reversal is: %d%d%d",c,b,a);
return 0;
}
3.重新编写编程题2中的程序,使新程序不需要利用算数分割就可以显示出3位数的逆序。提示:参考4.1节的upc.c程序。
#include<stdio.h>
int main()
{
int a,b,c;
printf("Enter a three_digit number: ");
scanf("%1d%1d%1d",&a,&b,&c);
printf("The reversal is: %d%d%d",c,b,a);
return 0;
}
4.编写一个程序,读入用户输入的整数并按八进制(基数为8)显示出来:
Enter a number between 0 and 32767: 1953
In octal, your number is: 03641
输出应为5位数,即便不需要这么多数位也要如此。提示:要把一个数转换成八进制,首先将除以8,所得的余数是八进制数的最后一位(本例中为1);然后把原始的数除以8,对除法结果重复上述过程,得到倒数第二位。(如第7章所示,printf 可以显示八进制的数,所以这个程序实际上有更简单的写法。)
#include<stdio.h>
int main()
{
int n,a,b,c,d,e;
printf("Please enter a number between 0 and 32767: ") ;
scanf("%d",&n);
e=n%8,d=n/8%8,c=n/8/8%8,b=n/8/8/8%8,a=n/8/8/8/8%8;
printf("The reversal is: %d%d%d%d%d",a,b,c,d,e);
return 0;
}
5.重写4.1节的upc.c程序,使用户可以一次输入11位数字,而不用先录入1位,再录入5位,最后再录入5位。
Enter the first 11 digits of a UPC: 01380015173
Check digit: 5
#include<stdio.h>
int main()
{
int a,b,c,d,e,f,g,h,i,j,k,l,m,n;
printf("Enter the first 11 digits of a UPC: ");
scanf("%1d%1d%1d%1d%1d%1d%1d%1d%1d%1d%1d",&a,&b,&c,&d,&e,&f,&g,&h,&i,&j,&k);
l=a+c+e+g+i+k,m=b+d+f+h+j,n=l*3+m;
printf("Check digit: %d",9-(n-1)%10);
return 0;
}
6.欧洲国家不使用北美的12位通用产品代码(UPC),而使用13位的欧洲商品编码(European Article Number,EAN)。跟 UPC 一样,每个EAN码的最后也有一个校验位。计算校验位的方法也类似:首先把第2位、第4位、第6位、第8位、第10位和第12位数字相加;然后把第1位、第3位、第5位、第7位、第9位和第11位数字相加;接着把第一次加法的结果乘以3,再和第二次加法的结果相加;随后,把上述结果减去1;相减后的结果除以10取余数;最后用9减去上一步骤中得到的余数。
以 Güllüoglu Turkish Delight Pistachio & Coconut 为例,其 EAN 码为8691484260008。第一个和为6+1+8+2+0+0=17,第二个和为8+9+4+4+6+0=31。第一个和乘以3再加上第二个和得到82,减1得到81。这个结果除以10的余数是1,再用9减去余数得到8,与原始编码的最后一位一致。请修改 4.1节的upc.c程序以计算 EAN 的校验位。用户把 EAN的前12位当作一个数输入:
Enter the first 12 digits of an EAN: 869148426000
Check digit: 8
#include<stdio.h>
int main()
{
int a,b,c,d,e,f,g,h,i,j,k,l,m,n,o;
printf("Enter the first 12 digits of a EAN: ");
scanf(" %1d%1d%1d%1d%1d%1d%1d%1d%1d%1d%1d%1d",&a,&b,&c,&d,&e,&f,&g,&h,&i,&j,&k,&l);
m=b+d+f+h+j+l,n=a+c+e+g+i+k,o=m*3+n;
printf("Check digit: %d",9-(o-1)%10);
return 0;
}