C Primer Plus第六章

1.编写一个程序,创建一个包含26个元素的数组,并在其中储存26个小写字母。然后打印数组的所有内容。

#include <stdio.h>
int main(void)
{
	char word[30];
	int index;
	
	for(index = 0;index<26;index++)
	{
		word[index] = 'a' + index;
	}
	for(index = 0;index<26;index++)
	{
		printf("%c ",word[index]);
	}
	
	return 0;
 } 

在这里插入图片描述
2.使用嵌套循环,按下面的格式打印字符:

在这里插入图片描述

#include <stdio.h>
int main(void)
{
	int i,j;
	
	for(i=0;i<5;i++)
	{
		for(j=0;j<=i;j++)
		{
			printf("$");
		}
		printf("\n");
	}
	
	return 0;
}

在这里插入图片描述
3.使用嵌套循环,按下面的格式打印字母:
F
FE
FED
FEDC
FEDCB
FEDCBA

#include <stdio.h>
int main(void)
{
	int i,j;
	char word[10];
	
	for(i=0;i<6;i++)
	{
		word[i]='F'-i;
	}
	for(i=0;i<6;i++)
	{
		for(j=0;j<=i;j++)
		{
			printf("%c",word[j]);
		}
		printf("\n");
	}
	
	return 0;
}

在这里插入图片描述
4.使用嵌套循环,按下面的格式打印字母:
A
BC
DEF
GHIJ
KLMNO
PQRSTU

#include <stdio.h>
int main(void)
{
	int i,j,index,a;
	char word[30];
	
	for(i=0;i<21;i++)
	{
		word[i]='A'+i;
	}
	for(i=0,a = 0;i<6;i++)
	{
		for(index=a,j=0;j<=i;j++,index++)
		{
			printf("%c",word[index]);
		}
		a += 1 + i;
		printf("\n");
	}
	
	return 0;

在这里插入图片描述
5.编写一个程序,提示用户输入大写字母。使用嵌套循环以下面金字塔型的格式打印字母;
在这里插入图片描述
打印这样的图形,要根据用户输入的字母来决定。例如,上面的图形是在用户输入E后的打印结果。提示:用外层循环处理行,每行使用3个内层循环,分别处理空格、以升序打印字母、以降序打印字母。如果系统不使用ASCII或其他以数字顺序编码的代码,请参照练习3的解决方案。

#include <stdio.h>
int main(void)
{
	char enter,ch1,ch2;
	int index,i,j,x,z;
	
	printf("请输入一个大写字母:\n");
	scanf("%c",&enter);
	index=enter - 'A' ;
	for(i=0;i<=index;i++)
	{
		//空格
		for(x=index-i;x>=0;x--)
		{
			printf(" ");
		 } 
		 //正序字母
		 for(ch1='A',j=0;j<=i;j++,ch1++) 
		 {
		 	printf("%c",ch1);
		 }
		 //倒序字母 
		 for(ch2='A'+i-1,z=0;z<i;z++,ch2--)
		 {
		 	printf("%c",ch2);
		 }
		 printf("\n");
	}
	return 0;
}

在这里插入图片描述
7.编写一个程序把一个单词读入一个字符数组中,然后倒序打印这个单词。提示: strlen ()函数(第4章介绍过)可用于计算数组最后一个字符的下标。

#include <stdio.h>
#include <string.h>
int main(void)
{
	char word[20];
	int n,i;
	
	printf("请输入一个单词:\n");
	scanf("%s",&word);
	n = strlen(word);
	for(i=1;i<=n;i++)
	{
		printf("%c",word[n-i]);
	}
	
	return 0;
 } 

在这里插入图片描述
8.编写一个程序,要求用户输入两个浮点数,并打印两数之差除以两数乘积的结果。在用户输入非数字之前,程序应循环处理用户输入的每对值。

#include <stdio.h>
int main(void)
{
	double n1,n2,x;
	int flag;
	
	printf("请输入两个浮点数:\n");
	flag = scanf("%lf %lf",&n1,&n2);
	while(flag==2)
	{
		x = ( n1 - n2 ) / ( n1 * n2 );
		printf("两数之差除以两数乘积的结果为:%.2lf\n",x); 
		printf("请再输入两个浮点数:\n");
	    flag = scanf("%lf %lf",&n1,&n2);
	}
	printf("退出\n");
	
	
	return 0;
 } 

在这里插入图片描述
9.修改练习8,使用一个函数返回计算的结果。

#include <stdio.h>
double jisuan(double n,double m);
int main(void)
{
	double n1,n2;
	int flag;
	
	printf("请输入两个浮点数:\n");
	flag = scanf("%lf %lf",&n1,&n2);
	while(flag==2)
	{
		jisuan(n1,n2);
		printf("请再输入两个浮点数:\n");
	    flag = scanf("%lf %lf",&n1,&n2);
	}
	printf("退出\n");
	
	
	return 0;
 } 
 double jisuan(double n1,double n2)
 {
 	double x;
 	
 	x = ( n1 - n2 ) / ( n1 * n2 );
	printf("两数之差除以两数乘积的结果为:%.2lf\n",x); 
 }

在这里插入图片描述
12.考虑下面两个无限序列:
1.0 + 1.0/2.0 + 1.0/3.0 + 1.0/ 4.0 + …
1.0 - 1.0/2.0 + 1.0/ 3.0 - 1.0/4.0 + …
编写一个程序计算这两个无限序列的总和,直到到达某次数。提示:奇数个-1相乘得-1,偶数个-1相乘得1。让用户交互地输入指定的次数,当用户输入0或负值时结束输入。查看运行100项、1000项、10000项后的总和,是否发现每个序列都收敛于某值?

#include <stdio.h>
int main(void)
{
	int n,i;
	double sum1 = 0;
	double sum2 = 0;
	double x;
	
	printf("请输入次数:\n");
	scanf("%d",&n);
	for(i=0;i<n&&n>0;i++)
	{
		sum1 = sum1 + ( 1.0 / ( i + 1.0 ));
		x = i % 2;
		if(x==0)
		{
			sum2 = sum2 + ( 1.0 / ( i + 1.0 ));
		}
		else
		{
			sum2 = sum2 - ( 1.0 / ( i + 1.0 ));
		}
	}
	printf("(1.0+1.0/2.0+1.0/3.0+....)结果为:%.2lf\n",sum1);
	printf("(1.0-1.0/2.0+1.0/3.0-....)结果为:%.2lf\n",sum2);
	
	return 0;
}

在这里插入图片描述
14.编写一个程序,创建两个包含8个元素的double类型数组,使用循环提示用户为第一个数组输入8个值。第二个数组元素的值设置为第一个数组对应元素的累积之和。例如,第二个数组的第4个元素的值是第一个数组前4个元素之和,第二个数组的第5个元素的值是第一个数组前5个元素之和(用嵌套循环可以完成,但是利用第二个数组的第5个元素是第二个数组的第4个元素与第一个数组的第5个元素之和,只用一个循环就能完成任务,不需要使用嵌套循环)。最后,使用循环显示两个数组的内容,第一个数组显示成一行,第二个数组显示在第一个数组的下一行,而且每个元素都与第一个数组各元素相对应。

#include <stdio.h>
int main(void)
{
	double enter[8];
	double sum[8];
	int i;
	
	printf("请输入8个数字:\n");
	for(i=0;i<8;i++)
	{
		printf("第%d个数字:",i+1);
		scanf("%lf",&enter[i]);
		printf("\n");
	}
	sum[0] = 0;
	for(i=0;i<8;i++)
	{
		sum[i] = sum[i-1] + enter[i];
	}
	for(i=0;i<8;i++)
	{
		printf("%-8.1lf",enter[i]);
	}
	printf("\n");
	for(i=0;i<8;i++)
	{
		printf("%-8.1lf",sum[i]);
    }
	printf("\n");
	
	return 0;
}

在这里插入图片描述
18. Rabnud博士加入了一个社交圈。起初他有5个朋友。他注意到他的朋友数量以下面的方式增长。第1周少了1个朋友,剩下的朋友数量翻倍;第2周少了2个朋友,剩下的朋友数量翻倍。一般而言,第N周少了N个朋友,剩下的朋友数量翻倍。编写一个程序,计算并显示Rabnud博士每周的朋友数量。该程序一直运行,直到超过邓巴数(Dunbar 's number)。邓巴数是粗略估算一个人在社交圈中有稳定关系的成员的最大值,该值大约是150。

#include <stdio.h>
#define DUNBAR_NUMBER 150
int main(void)
{
	int n,i;
	int sum = 5;
	
	for(n=1;sum<DUNBAR_NUMBER;n++)
	{
		i=sum;
		sum = 2 * (i - n) ;
		printf("第%d周:%d个朋友\n",n,sum);
	}
	
	return 0;
}

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值