c primer plus(五版)编程练习-第六章编程练习
1.编写一个程序,创建一个具有26 个元素的数组,并在其中存储26 个小写字母。并让该程序显示该数组的内容。
#include<stdio.h>
#define SIZE 26
int main(void){
int letter[SIZE];
int i;
for(i=;i<SIZE;i++){
letter[i] = 'a'+i;
}
for(i=;i<SIZE;i++){
printf("The ASCII value for %c is %d \n",letter[i],letter[i]);
}
return ;
}
2.使用嵌套循环产生下列图案:
$
$$
$$$
$$$$
$$$$$
#include<stdio.h>
int main(void){
int i,j;
for(i=;i<;i++){
for(j=;j<=i;j++){
printf("$");
}
printf("\n");
}
return ;
}
3,使用嵌套循环产生下列图案:
F
FE
FED
FEDC
FEDCB
FEDCBA
#include<stdio.h>
int main(void){
char letter[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
int i,j;
for(i=;i>=;i--){
for(j=;j>=i;j--){
printf("%c",letter[j]);
}
printf("\n");
} /* for(i=0;i<6;i++){
for(j=5;j>=i;j--){
printf("%c",letter[j]);
}
printf("\n");
}
return 0;
//output:
FEDCBA
FEDCB
FEDC
FED
FE
F*/ }
4.让程序要求用户输入一个大写字母,使用嵌套循环产生像下面这样的金字塔图案:
A
ABA
ABCBA
ABCDCDA
ABCDEDCBA
这种图案要扩展到用户输入的字符。例如,前面的图案是在输入E 时需要产生的。提示:使用一个外部循环来处理行,在每一行中使用三个内部循环,一个处理空格,一个以升序打印字母,一个以降序打印字母。如果您的系统不使用ASCII 或类似的以严格数字顺序表示字母的编码,请参见在编程练习3 中给出的建议。
#include<stdio.h>
int main(void){
char letter[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char input_let;
int i,j,k;
//A:65,Z:90;
printf("请输入一个大写字母:"); scanf("%c",&input_let);
/*for(i=0;i<input_let-65+1;i++){
for(j=0;j<input_let - 65-i;j++){
printf(" ");
}
for(j=0;j<=i;j++){
printf("%c",'A'+j);
}
for(k=i-1;k>=0;k--){
printf("%c",'A'+k);
}
printf("\n");
}*/
for(i=;i<input_let-+;i++){
for(j=;j<input_let - -i;j++){
printf(" ");
}
for(j=;j<=i;j++){
printf("%c",letter[j]);
}
for(k=i-;k>=;k--){
printf("%c",letter[k]);
}
printf("\n");
}
return ;
}
5.编写一个程序打印一个表,表的每一行都给出一个整数、它的平方以及它的立方。要求用户输入表的上限与下限。使用一个for 循环。
#include<stdio.h>
int main(void){
int i,n1,n2;
printf("请输入一个最小值和一个最大值,程序将列出他们的平方和立方:");
scanf("%d%d",&n1,&n2);
printf("数字 | 平方 | 立方\n");
for(i=n1;i<=n2;i++){
printf("%d | %d | %d\n",i,i*i,i*i*i);
}
return ;
}
6.编写一个程序把一个单词读入一个字符数组,然后反向打印出这个词。提示:使用strlen()(第4 章)计算数组中最后一个字符的索引。
#include<stdio.h>
#include<string.h>
int main(void){
char word[];
int i,length;
printf("请输入一下英文单词:\n");
scanf("%s",&word);
length = strlen(word);
for(i=length-;i>=;i--){
printf("%c",word[i]);
}
return ;
}
7.编写一个程序,要求输入两个浮点数,然后打印出用二者的差值除以二者的乘积所得的结果。在用户键入非数字的输入之前程序循环处理每对输入值。
#include<stdio.h>
int main(void){
float n1,n2;
printf("请输入两个数字:");
while(scanf("%f%f",&n1,&n2)==){
printf("max_float - min_float) / (max_float * min_float) = %f\n",(n1-n2)/(n1*n2));
}
return ;
}
8.对练习7 进行修改,让它使用一个函数来返回计算值。
#include<stdio.h>
float calc(float n1, float n2);
int main(void){
float n1,n2,result;
printf("请输入两个数字:");
while(scanf("%f%f",&n1,&n2)==){
result = calc(n1,n2);
printf("max_float - min_float) / (max_float * min_float) = %f\n",result );
}
return ;
}
float calc(float n1,float n2){
return (n1-n2)/(n1*n2);
}
9.编写一个程序,要求用户输入下限整数和一个上限整数,然后,依次计算从下限到上限的每一个整数的平方的加和,最后显示结果。程序将不断提示用户输入下限整数和上限整数并显示出答案,直到用户输入的上限整数等于或小于下限整数为止。程序运行的结果示例应该如下所示:
Enter lower and upper integer limits:5 9
The sums of the squares from 25 to 81 is 255
Enter next set of limits:3 25
The sums of the squares from 9 to 625 is 5520
Enter next set of limits:5 5
Done
#include<stdio.h>
int main(void){
int n1,n2,i,count;
printf("Enter lower and upper integer limits:");
scanf("%d%d",&n1,&n2);
while(n2>n1){
count = ;
for(i=n1;i<=n2;i++){
count += i*i;
}
printf("The sums of the squares from %d to %d is %d .\n",n1*n1,n2*n2,count);
printf("Enter next set of limits:");
scanf("%d%d",&n1,&n2);
}
printf("done");
return ;
}
10.编写一个程序把8 个整数读入一个数组中,然后以相反的顺序打印它们
#include<stdio.h>
int main(void){
int i,num,num_arr[];
printf("Enter 8 integers:");
i=;
while(i<){
scanf("%d",&num);
num_arr[i] = num;
i++;
}
for(i=-;i>=;i--){
printf("%3d",num_arr[i]);
} return ;
}
11.考虑这两个无限序列:
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+...
编写一个程序来计算这两个序列不断变化的总和,直到达到某个次数。让用户交互地输入这个次数。看看在20 次、100 次和500 次之后的总和。是否每个序列都看上去要收敛于某个值?提示:奇数个-1 相乘的值为-1,而偶数个-1 相乘的值为1。
#include<stdio.h>
int main(void){
int i,num;
double count1,count2,count;
int temp = ;
count1 = ;
count2 = ;
printf("请输入一个整数:");
scanf("%d",&num);
for(i=;i<=num;i++){
count1 +=1.0/i; count2 +=1.0/i*temp;
temp*=-;
count+=count1+count2;
}
printf("1.0+1.0/2.0+1.0/3.0+1.0/4.0+... %d = %f\n",num,count1);
printf("1.0-1.0/2.0+1.0/3.0-1.0/4.0+... %d = %f\n",num,count2);
printf("1.0+1.0/2.0+1.0/3.0+1.0/4.0+ ... %d + 1.0-1.0/2.0+1.0/3.0-1.0/4.0+... %d = %f",num,num,count);
return ;
}
12.编写一个程序,创建一个8 个元素的int 数组,并且把元素分别设置为2 的前8 次幂,然后打印出它们的值。使用for 循环来设置值;为了变化,使用do while 循环来显示这些值。
#include<stdio.h>
#define SIZE 8
int main(void){
int i,num_arr[SIZE];
int num = ;
for(i=;i<=SIZE;i++){
num *= ;
num_arr[i] = num;
}
i=;
do{
printf("%d\n",num_arr[i]);
i++;
}while(i<); return ;
}
13.编写一个程序,创建两个8 元素的double 数组,使用一个循环来让用户键入第一个数组的8 个元素的值。程序把第二个数组的元素设置为第一个数组元素的累积和。例如,第二个数组的第4个元素应该等于第一个数组的前4 个元素的和,第二个数组的第5 个元素应该等于第一个数组的前5个元素的和(使用嵌套循环可以做到这一点。不过利用第二个数组的第5 个元素等于第二个数组的第4 个元素加上第一个数组的第5 个元素这一事实,可以避免嵌套而只使用单个循环来完成这个任务)。最后,使用一个循环来显示两个数组中的内容,第一个数组在一行中显示,而第二个数组中的每个元素在第一个数组的对应元素之下进行显示。
#include<stdio.h>
#define SIZE 8
int main(void){
double arr1[SIZE];
double arr2[SIZE];
double input_num;
int i;
i = ; while(i<SIZE){
printf("请输入一个数字:\n");
scanf("%lf",&input_num);
arr1[i] = input_num;
i++; }
arr2[] = arr1[];
for(i=;i<SIZE;i++){
arr2[i] = arr1[i]+arr2[i-];
}
for(i=;i<SIZE;i++){
printf("%.2f ",arr1[i]); }
printf("\n");
for(i=;i<SIZE;i++){
printf("%.2f ",arr2[i]);
}
return ;
}
题目中说“使用一个循环来显示两个数组中的内容”,但是我实在想不出,如何使用一个循环达到题目所要求的输出效果——分两行显行,并且两个数组的值一一对应。
14.编写一个程序读入一行输入,然后反向打印该行。您可以把输入存储在一个char 数组中;假定该行不超过255 个字符。回忆一下,您可以使用具有%c 说明符的scanf()从输入中一次读入一个字符,而且当您按下回车键时会产生换行字符(\n)。
#include<stdio.h>
#include<string.h>
int main(void){
char str[];
char temp;
int i,length;
printf("请输入一行字符:\n");
scanf("%s",str);
length = strlen(str);
for(i=length-;i>=;i--){
printf("%c",str[i]);
}
return ;
}
15.Daphne 以10%的单利息投资了100 美元(也就是说,每年投资赢得的利息等于原始投资的10%)。Deirdre 则以每年5%的复合利息投资了100 美元(也就是说,利息是当前结余的5%,其中包括以前的利息)。编写一个程序,计算需要多少年Deirdre 的投资额才会超过Daphne,并且显示出到那时两个人的投资额。
#include<stdio.h>
#define BASE 100
#define RATE1 0.1
#define RATE2 0.05
int main(void){
float count1,count2;
int i;
count1 = BASE;
count2 = BASE;
i=;
while(count1>=count2){ count1+=BASE*RATE1;
count2+=count2*RATE2;
i++;
}
printf("%d year Daphne:%.2f Deirdre:%.2f",i,count1,count2);
return ;
}
16.Chuckie Lucky 赢了100 万美元,他把它存入一个每年赢得8%的帐户。在每年的最后一天,Chuckie 取出10 万美元。编写一个程序,计算需要多少年Chuckie 就会清空他的帐户。
#include<stdio.h>
#define BASE 100
#define CHECKOUT 10
#define RATE 0.08
int main(void){
int i;
int account;
account = BASE;
i = ;
while(account>){
account +=account*RATE;
account -=CHECKOUT;
i++;
}
printf("%d year Chuckie account is 0",i);
return ;
}
c primer plus(五版)编程练习-第六章编程练习的更多相关文章
- 《C++Primer》第五版习题答案--第六章【学习笔记】
<C++Primer>第五版习题答案--第六章[学习笔记] ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/16 第六章:函数 ...
- 实验楼课程管理程序-深入学习《C++ Primer第五版》实验报告&学习笔记1
本片博客为实验楼的训练营课程深入学习<C++ Primer第五版>的实验报告和学习笔记. 原课程地址为:https://www.shiyanlou.com/courses/405# 原文出 ...
- C++ 11 从C++ primer第五版的学习笔记
1. auto (page107) auto 推断会忽略const const int ci = i, & cr = ci; auto b = ci; // b is an int (to ...
- 《C++Primer》第五版习题解答--第四章【学习笔记】
[C++Primer]第五版习题解答--第四章[学习笔记] ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/11 第四章:表达式 练习4. ...
- C++PRIMER第五版练习题答案第一章
C++PRIMER第五版练习题答案第一章 应该有很多小伙伴和我一样,闲来无事买了本C++的书自己啃,课后的练习题做的很揪心,这里我分享下我写的答案,希望能帮助到你,提供源码,就不跑了哈,毕竟现在是第一 ...
- [书籍翻译] 《JavaScript并发编程》第六章 实用的并发
本文是我翻译<JavaScript Concurrency>书籍的第六章 实用的并发,该书主要以Promises.Generator.Web workers等技术来讲解JavaScript ...
- C++Primer第五版学习笔记
<C++ Primer>Learning Note 程序实例下载地址:http://www.informit.com/title/0321714113 第一章 开始 ...
- 《C++Primer》第五版习题答案--第三章【学习笔记】
[C++Primer]第五版[学习笔记]习题解答第三章 ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/10 第三章:字符串,向量和数组 ...
- C++Primer第五版——习题答案和解析
感谢原文博主的分享:https://blog.csdn.net/misayaaaaa/article/details/53786215 新手入门必看的书.知识是一个系统化并且相互关联的体系,零散的东西 ...
随机推荐
- Android中使用UncaughtExceptionHandler来处理未捕获的异常
原文在sparkyuan.me上.转载注明出处:http://sparkyuan.github.io/2016/03/28/使用UncaughtExceptionHandler来处理未捕获的异常/ 全 ...
- mybatis由浅入深day02_3一对多查询
3 一对多查询 3.1 需求(查询订单及订单明细的信息) 查询订单及订单明细的信息. 3.2 sql语句 确定主查询表:订单表 确定关联查询表:订单明细表 在一对一查询基础上添加订单明细表关联即可. ...
- try catch finally的执行顺序
1.将预见可能引发异常的代码包含在try语句块中. 2.如果发生了异常,则转入catch的执行.catch有几种写法: catch 这将捕获任何发生的异常. catch(Exception e) 这将 ...
- 【RF库Collections测试】Get From List
Name:Get From ListSource:Collections <test library>Arguments:[ list_ | index ]Returns the valu ...
- Anfroid 在界面中显示图片 ImageView
ImageView1.什么是ImageView是显示图片的一个控件2.ImageView属性android:src ImageView的内容颜色 android:background ImageVie ...
- spring aop 样例
基于注解的AOP 方式 1.加入jar包 com.springsource.org.aopalliance-1.0.0.jar com.springsource.org.aspectj.weaver- ...
- JZOJ.5329【NOIP2017模拟8.22】时间机器
Description
- bootstrap之
一.字体图标 <button type="button" class="btn btn-primary btn-lg"> <span clas ...
- elasticsearch-1.2.1客户端连接DEMO
1.下载elasticsearch-1.2.1的zip包,解压之后 双击bin目录中的 elasticsearch.bat(针对windows系统) 启动服务器(默认监听9200端口) 访问 http ...
- 云计算之路-阿里云上:消灭“黑色n秒”第一招——不让CPU空闲
昨天对“黑色n秒”问题的最终猜想以失败而告终,从而让我们结束了被动猜想阶段,进入了主动进攻阶段——出招. 今天出第一招——用C#写个小程序,让其在每个CPU核上运行一个线程,不让任何一个CPU核进入空 ...