码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2020-02-02 23:21:24      阅读:222      评论:0      收藏:0      [点我收藏+]

标签:def   其他   次数   argument   bsp   struct   例子   ios   填充   

第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);

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

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

标签:def   其他   次数   argument   bsp   struct   例子   ios   填充   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!