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(五版)编程练习-第六章编程练习的更多相关文章

  1. 《C++Primer》第五版习题答案--第六章【学习笔记】

    <C++Primer>第五版习题答案--第六章[学习笔记] ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/16 第六章:函数 ...

  2. 实验楼课程管理程序-深入学习《C++ Primer第五版》实验报告&学习笔记1

    本片博客为实验楼的训练营课程深入学习<C++ Primer第五版>的实验报告和学习笔记. 原课程地址为:https://www.shiyanlou.com/courses/405# 原文出 ...

  3. C++ 11 从C++ primer第五版的学习笔记

    1. auto (page107) auto 推断会忽略const   const int ci = i, & cr = ci; auto b = ci; // b is an int (to ...

  4. 《C++Primer》第五版习题解答--第四章【学习笔记】

    [C++Primer]第五版习题解答--第四章[学习笔记] ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/11 第四章:表达式 练习4. ...

  5. C++PRIMER第五版练习题答案第一章

    C++PRIMER第五版练习题答案第一章 应该有很多小伙伴和我一样,闲来无事买了本C++的书自己啃,课后的练习题做的很揪心,这里我分享下我写的答案,希望能帮助到你,提供源码,就不跑了哈,毕竟现在是第一 ...

  6. [书籍翻译] 《JavaScript并发编程》第六章 实用的并发

    本文是我翻译<JavaScript Concurrency>书籍的第六章 实用的并发,该书主要以Promises.Generator.Web workers等技术来讲解JavaScript ...

  7. C++Primer第五版学习笔记

    <C++ Primer>Learning Note 程序实例下载地址:http://www.informit.com/title/0321714113 第一章            开始 ...

  8. 《C++Primer》第五版习题答案--第三章【学习笔记】

    [C++Primer]第五版[学习笔记]习题解答第三章 ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/10 第三章:字符串,向量和数组 ...

  9. C++Primer第五版——习题答案和解析

    感谢原文博主的分享:https://blog.csdn.net/misayaaaaa/article/details/53786215 新手入门必看的书.知识是一个系统化并且相互关联的体系,零散的东西 ...

随机推荐

  1. CSS 解决IE6双倍距离BUG

    只要满足下面3个条件才会出现这个BUG: 1)要为块状元素:        2)要左侧浮动:        3)要有左外边距(margin-left): 解决这个BUG很容易,只需要在相应的块状元素的 ...

  2. linux环境中,nginx安装过程

    需求描述: 记录在linux平台,nginx安装的过程. 环境描述: 操作系统:Red Hat Enterprise Linux Server release 6.6 (Santiago) 操作内核版 ...

  3. 【RF库Collections测试】Copy Dictionary

    Name: Copy DictionarySource:Collections <test library>Arguments:[ dictionary ]Returns a copy o ...

  4. isdigit()

    isdigit() 是字符串的一个方法,用来判断这个字符串是否是纯数字的字符串 In [1]: str = 'hello' In [2]: str.isdigit() Out[2]: False In ...

  5. Tomcat在Linux下的安装与配置

    一.安装配置JDK 1.官网下载JDK1.7 mkdir /usr/java cd /uar/java wget http://download.oracle.com/otn/java/jdk/7u8 ...

  6. 微信小程序 this.setData 修改json里面的值

    page({ data:{ s1:{a:"",b:"b"} }, changeData:function(e){ var cData=this.data.s1; ...

  7. PHP之变量

    前面的话 变量是用于临时存储值的容器.这些值可以是数字.文本,或者复杂得多的排列组合.变量在任何编程语言中都居于核心地位,理解它们是使用php的关键所在.下面将详细介绍php中的变量 [注意]关于ja ...

  8. poj_2774 后缀数组

    题目大意 给定两个字符串A,B,求出A和B中最长公共子串的长度. 题目分析 字符串的子串可以认为是是字符串的某个后缀的前缀,而求最长公共子串相当于A和B的某两个后缀的最长相同前缀.可以考虑使用后缀数组 ...

  9. 【ecshop】使用sql 清除测试数据

    操作方式:后台->数据库->sql查询   输入以下你想进行的操作 -- -- 清空会员有关数据: -- TRUNCATE TABLE `ecs_users` ; TRUNCATE TAB ...

  10. cookie带来的致命危险

    1.危险:当记录了过多的cookie时,可能导致http header过大,进而导致服务器端发生错误,导致用户无法打开页面. 2.cookie限制: 各浏览器对单cookie键的限制基本都在4kb左右 ...