C语言程序设计现代方法—第2版 第4章 编程答案

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;
}

  • 10
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值