《C++ primer plus 》复习题与编程练习(06)

第7章 函数——C++的编程模块

复习题

1 使用函数的3个步骤是什么?

2 请创建与下面的描述匹配的函数原型。

a. igor() 没有参数,且没有返回值。

b. tofu() 接受一个 int 参数,并返回一个 float。

c. mpg() 接受两个 double参数,并返回一个 double。

d. summation() 将 long 数组名和数组长度作为参数,并返回一个 long 值。

e. doctor() 接受一个字符串参数(不能修改该字符串),并返回一个 double 值。

f. ofcourse() 将 boss 结构作为参数,不返回值。

g. plot() 将 map 结构的指针作为参数,并返回一个字符串。

3. 编写一个接受3个参数的函数:int 数组名、数组长度和一个 int 值,并将数组的所有元素都设置为 int 值。

4. 编写一个接受3个参数的函数:指向数组区间中第一个元素的指针、指向数组区间最后一个元素后面的指针以及一个 int 值,并将数组中的每个元素都设置为该int值。

5. 编写将 double 数组名和数组长度作为参数,并返回该数组中最大值的函数,该函数不应修改数组的内容。

6. 为什么不对类型为基本类型的函数参数使用 const 限定符?

7. C++程序可使用哪 3 种 C 风格字符串格式?

8.编写一个函数,其原型如下:

int replace(char * str, char c1, char c2);

该函数将字符串中所有的 c1 都替换为 c2,并返回替换次数。

9. 表达式 *“pizza” 的含义是什么? "taco” [2] 呢?

10. C++允许按值传递结构,也允许传递结构的地址、如果 glitz 是一个结构变量,如何按值传递它?如何传递它的地址?这两种方法有何利弊?

11.函数 judge() 的返回类型为 int,它将这样一个函数的地址作为参数:将 const char指针作为参数并返回一个m值,请编写 judge() 函数的原型。

12.假设有如下结构声明:

struct applicant {
char name[30];
int credit_ratings[3];
};

a 编写一个函数,它将 application结构作为参数,并显示该结构的内容。

b 编写一个函数,它将 application结构的地址作为参数,并显示该参数指向的结构的内容 。

13.假没函数 f1() 和 f2() 的原型如下:

void f1(applicant * a);
const char * f2(const applicant * a1, const applicant * a2);

请将 p1 和 p2 分别声明为指向 f1() 和 f2() 的指针;将 ap 声明为一个数组,它包含5个类型与 p1 相同的指针;将 pa 声明为一个指,它指向的数组包含10个类型与 p2 相同的指针,使用 typedef 来帮助完成这项工作。

编程练习

1. 编写一个程序,不断要求用户输入两个数,直到其中的一个为0。对于每两个数,程序将使用一个函数来计算它们的调和平均数,并将结果返回给 main(),而后者将报告结果,调和平均数指的是倒数平均值的倒数,计算公式如下

调和平均数=2.0 * x * y / ( x + y )

2. 编写一个程序,要求用户输入最多 10 个高尔夫成绩,并将其存储在一个数组中。程序允许用户提早结束输入,并在一行上显示所有成绩,然后报告平均成绩。请使用3个数组处理函数来分别进行轴人显示和计算平均成绩。

3.下面是一个结构声明:

struct box
{
    char maker[40];
    float height;
    float width;
    float length;
    float volume;
};

a.编写一个函数,按值传递 box 结构,并显示每个成员的值。

b.编写一个函数,传递 box 结构的地址,并将 volume 成员设置为其他三维长度的乘积。

c,编写一个使用这两个函数的简单程序 。

4,  许多州的彩票发行机构都使用如程序清单 7.4 所示的简单彩票玩法的变体,在这些玩法中,玩家从一组被称为域号码( field number)的号码中选择几个,例如,可以从域号码1~47中选择5个号码:还可以从第二个区间(如1-27)选择一个号码(你为特选号码),要赢得头奖,必须正确猜中所有的号码。中头奖的儿率是选中所有域号码的几率与选中特选号码几率的乘积。例如,在这个例子中,中头奖的几率是从47个号码中正确选取5个号码的几率与从27个号码中正确选择1个号码的几率的乘积,请修改程序单7,4,以计算中得这种彩票头奖的几率。

5.定义一个递归函数,接受一个整数参数,并返回该参数的阶乘,前面讲过,3的阶乘写作3!,等于32,依此类推:而 0 被定义为 1。 通用的计算公式是,如果 n 大于零,则n=n(n-1)!。在程序中对该函数进行测试,程序使用循环让用户输入不同的值,程序将报告这些值的阶乘。

6. 编写一个程序,它使用下列函数:

Fill_array() 将一个 double 数组的名称和长度作为参数。它提示用户输入 double 值,并将这些值存储到数组中,当数组被填满或用户输入了非数字时,输入将停止,并返回实际输入了多少个数字。

Show_array() 将一个 double数组的名称和长度作为参数,并显示该数组的内容。

Reverse_array() 将一个 double数组的名称和长度作为参数,并将存储在数组中的值的顺序反转。

程序将使用这些函数来填充数组,然后显示数组;反转数组,然后显示数组;反转数组中除第一个和后一个元素之外的所有元素,然后显示数组。

7. 修改程序清单 7.7 中的3个数组处理函数,使之使用两个指针参数来表示区间。fill_array()函数不返回实际读取了多少个数字,而是返回一个指针,该指针指向最后被填充的位置;其他的函数可以将该指 针作为第二个参数,以标识数据结尾。

8. 在不使用 array 类的情况下完成程序清单 7.15 所做的工作,编写两个这样的版本:

a. 使用 const char * 数组存储表示季度名称的字符串,并使用 double数组存储开支。

b. 使用 const char * 数组存储表示季度名称的字符串,并使用一个结构,该结构只有一个成员——一个用于存储开支的 double数组。这种设计与使用 array 类的基本设计类似。

9. 这个练习让您编写处理数组和结构的函数,下面是程序的框架,请提供其中描述的函数。以完成该程序。

#include <iostream>
using namespace std;

const int SLEN = 30;
struct student {
    char fullname[SLEN];
    char hobby[SLEN];
    int ooplevel;
};
// getinfo() has two arguments: a pointer to the first element of
// an array of student structures and an int representing the
// number of elements of the array. The function solicits and
// stores data about students. It terminates input upon filling
// the array or upon encountering a blank line for the student
// name. The function returns the actual number of array elements
// filled.
int getinfo(student pa[], int n);
// display1() takes a student structure as an argument
// and displays its contents
void display1(student st);
// display2() takes the address of student structure as an
// argument and displays the structure’s contents
void display2(const student * ps);
// display3() takes the address of the first element of an array
// of student structures and the number of array elements as
// arguments and displays the contents of the structures
void display3(const student pa[], int n);
int main()
{
    cout << “Enter class size: “;
    int class_size;
    cin >> class_size;
    while (cin.get() != ‘\n’)
        continue;
    student * ptr_stu = new student[class_size];
    int entered = getinfo(ptr_stu, class_size);
    for (int i = 0; i < entered; i++)
    {
        display1(ptr_stu[i]);
        display2(&ptr_stu[i]);
    }
    display3(ptr_stu, entered);
    delete [] ptr_stu;
    cout << “Done\n”;
    return 0;
}

10. 设计一个名为 calculate() 的函数,它接受两个 double 值和一个指向函数的指针,而被指向的函数接受两个 double 参数,并返回一个 double 值。calculate()函数的类型也是 double,并返回被指向的函数使用 calculat() 的两个 double 参数计算得到的值,例如,假设add() 函数的定义如下:

double add(double x, double y)
{
    return x + y;
}

则下述代码中的函数调用将导致 calculate() 把 25 和 104 传递给 add() 函数,并返回 add() 的返回值(12.9):

double q = calculate(2.5, 10.4, add);

编写一个程序,它调用上述两个函数和至少另一个与 add() 类似的函数。该程序使用循环来让用户成对地输入数字。对于每对数字,程序都使用 calculat() 来调用 add() 和至少一个其他的函数。如果读者爱冒险,可以尝试创建一个指针数组,其中的指针指向 add() 样式的函数,并编写一个循环,使用这些指针连续让 calculate() 调用这些函数。提示:下面是声明这种指针数组的方式,其中包含三个指针:

double (*pf[3])(double, double);

可以采用数组初始化语法,并将函数名作为地址来初始化这样的数组。

原文地址:https://www.cnblogs.com/mrray1105/p/12003873.html

时间: 2024-10-13 19:36:38

《C++ primer plus 》复习题与编程练习(06)的相关文章

《C++ primer plus 》复习题与编程练习(03)

复习题 1.如何声明下述数据? a. actor是由30个char组成的数组. b. betsie是由100个short组成的数组. c. chuck是由13个float组成的数组. d. dipsea是由64个 long double 组成的数组. 2.使用模板类array而不是数组来完成问题1. 3.声明一个包含5个元素的 int 数组,并将它初始化为前5个正奇数. 4.编写一条语句,将问题 3 中数组第一个元素和最后一个元素的和赋给变量 even. 5. 编写一条语句,显示 float 数

《C++ primer plus 》复习题与编程练习(04)

第5章 循环和关系表达式 复习题 1. 入口条件循环和出口条件循环之间的区别是什么?各种C++循环分别属于其中的哪一种? 2. 如果下面的代码片段是有效程序的组成部分,它将打印什么内容? int i; for (i = 0; i < 5; i++) cout << i; cout << endl; 3. 如果下面的代码片段是有效程序的组成部分,它将打印什么内容? int j; for(j = 0; j < 11; j += 3) cout << j; cou

C Primer plus 第二章复习题及其编程题

1  答: 函数 2  语法错误在C语言中就是写错了程序 比如说int a=5 没有加分号 就是语法错误 3  语义错误就是写的代码没有错 但和自己想实现的是不一样的 比如我们要计算1+1是多少 写成了1-1 就是语义错误 4 这个代码错误百出 如果征求我的意见的话 我会对他说:''兄弟 前途无量啊!! include stdio.hint main(void)(int s;s;=56;print(There are s week in a year .);return 0;) 修改后为 #in

C Primer plus 第一章复习题及其编程题

1 就编程而言 可移植性表示什么 答:可移植性代表C源代码不经修改就能在多种不同的计算机系统上编译成可以运行的程序 2 解释源代码文件 目标代码文件 和可执行文件之间的区别 答:源代码文件包含程序员用任何语言编写的代码 目标代码文件包含着机器语言代码,它并需要是完整的程序代码.可执行文件包含着组成可执行程序的全部机器语言代码. 3 编程的7个步骤 定义程序目标->设计程序->编写程序代码->编译程序->运行程序->测试和调试程序->维护和修改程序(可能要迭代进行) 4编

《C++ Primer》之面向对象编程(四)

纯虚函数 在前面所提到过的 Disc_item 类提出了一个有趣的问题:该类从 Item_base 继承了 net_price 函数但没有重定义该函数.因为对 Disc_item 类而言没有可以给予该函数的意义,所以没有重定义该函数.在我们的应用程序中,Disc_item 不对应任何折扣策略,这个类的存在只是为了让其他类继承.//也就是说,Disc_item继承了Item_base中的虚函数net_price,但是由于Disc_item不需要net_price,所以它没有重定义net_price

《C++ Primer》之面向对象编程(三)

继承情况下的类作用域 在继承情况下,派生类的作用域嵌套在基类作用域中.如果不能在派生类作用域中确定名字,就在外围基类作用域中查找该名字的定义.正是这种类作用域的层次嵌套使我们能够直接访问基类的成员,就好象这些成员是派生类成员一样.如果编写如下代码: Bulk_item bulk; cout << bulk.book(); 名字 book 的使用将这样确定:bulk 是 Bulk_item 类对象,在 Bulk_item 类中查找,找不到名字 book:因为从 Item_base 派生 Bulk

c primer plus(五版)编程练习-第七章编程练习

1.编写一个程序.该程序读取输入直到遇到#字符,然后报告读取的空格数目.读取的换行符数目以及读取的所有其他字符数目. #include<stdio.h> #include<ctype.h> int main(void){ char ch; int count1,count2,count3; count1 = count2 = count3 = 0;  printf("Enter text to be analyzed(#to terminate):\n"); w

Java基础知识强化之网络编程笔记06:TCP之TCP协议发送数据 和 接收数据

1. TCP协议发送数据 和 接收数据 TCP协议接收数据:• 创建接收端的Socket对象• 监听客户端连接.返回一个对应的Socket对象• 获取输入流,读取数据显示在控制台• 释放资源 TCP协议发送数据: • 创建发送端的Socket对象• 这一步如果成功,就说明连接已经建立成功了.• 获取输出流,写数据• 释放资源 2. 代码实现: (1)发送端: 1 package cn.itcast_06; 2 3 import java.io.IOException; 4 import java

c++primer 第四章编程练习答案

4.13.1 #include<iostream> struct students { char firstname[20]; char lastname[20]; char grade; int age; }; int main() { using namespace std; students student1; cout << "What is your fistname? "; cin.get(student1.firstname, 20).get();