C++ Primer第八章课后编程题

1.编写通常接受一个参数(字符串的地址),并打印该字符串的函数。不过,如果提供了第二个参数(int类型),且该参数不为0,则该函数打印字符串的次数将为该函数被调用的次数(注意,字符串的打印次数不等于第二个参数的值,而等于函数被调用的次数)。是的,这是一个非常可笑的函数,但它让读者能够使用本章介绍的一些技术。在一个简单的程序中使用该函数,以演示该函数是如何工作的。

代码:

#include<iostream>
using namespace std;
void show(const char * a, int b=0);
void show(const char * a, int b)
{
    static int uses = 0;
    int lim = ++uses;
    cout << "第" << uses << "次调用.\n";
    if(b==0)
        lim = 1;
    for (int i=0; i<lim; i++)
        cout <<a<<endl;
}
int main()
{
    int i;
    const char * p = "hello world\n";
    cout <<"输入函数调用次数:";
    cin >> i;
    while(i>=0)
    {
        cout << "参数n为:" <<i;
        show(p, i);
        i--;
    }
    cout << "默认n为0:";
    show(p);
    return 0;
}    

运行结果:

2、CandyBar结构饱含3个成员。第一个成员存储candy bar的品牌名称;第二个成员存储candy bar的重量(可能有小数);第三个成员存储candy bar的热量(整数)。请编写一个程序,它使用一个这样的函数,即将CandyBar的引用、char指针、double和int作为参数,并用最后3个值设置相应的结构成员。最后3个参数的默认值分别为"Millennium
Munch"、2.85和350。另外,该程序还包含一个以CandyBar的引用为参数,并显示结构内容的函数。请尽可能使用const.

代码

#include<iostream>
#include<cstring>
using namespace std;
const int MAX=60;
struct CandyBar{
    char brand[MAX];
    double weight;
    int energy;
};
void init(
    CandyBar & cb,
    const char *br = "Millennium Munch",
    double we = 2.85,
    int ca = 350
);
void display(const CandyBar & cb);
int main()
{
    CandyBar candybar;
    cout << "默认的candybar为:"<<endl;
    init(candybar);
    display(candybar);
    char newBrand[MAX];
    double newWeight;
    int newEnergy;
    cout << "请输入新的candybar数据:"<<endl;
    cout << "brand: ";
    cin.get(newBrand, MAX);
    cout << "weight: ";
    cin >> newWeight;
    cout << "Energy: ";
    cin >> newEnergy;
    init(candybar, newBrand, newWeight, newEnergy);
    display(candybar);
    return 0;
}
void init(CandyBar &cb,const char *br, double we, int ca)
{
    strcpy(cb.brand, br);
    cb.weight = we;
    cb.energy = ca;
}
void display(const CandyBar &cb)
{
    cout << "新的candybar为:\n";
    cout << "brand: " << cb.brand<<endl;
    cout << "weight: "<<cb.weight<<endl;
    cout << "energy: "<<cb.energy<<endl;
}

运行结果

3、编写一个函数,它接受一个指向string对象的引用作为参数,并将该string对象的内容转换为大写,为此可使用函数toupper()。.然后编写一个程序,它通过使用一个循环让你能够用不同的输入来测试这个函数,该程序运行情况如下:

enter a string (q to quit) :go awayGO AWAYnext string (q to quit) : good grief !GOOD GRIEF!next string (q to quit) : qbye.

代码:

#include<iostream>
#include<string>
using namespace std;
void wordupper(string &a);
int main()
{
    string str;
    cout << "Enter a string (1 to quit):";
    getline(cin, str);
    int i=0;
    while (str != "q")
    {
        wordupper(str);
        cout << str <<endl;
        cout << "next string (q to quit):";
        getline(cin, str);
    }
    cout << "bey!\n";
    return 0;
}
void wordupper(string &a)
{
    int i;
    while (a[i])
    {
        a[i] = toupper(a[i]);
        i++;
    }
}

运行结果:

5、编写模板函数max5(),它将一个包含5个T类型元素的数组作为参数,并返回数组中最大的元素(由于长度固定,因此可以在循环中使用硬编码,而不必通过参数来传递)。在一个程序中使用该函数,将T替换为一个包含5个int值的数组和一个包含5个dowble值的数组,以测试该函数。

代码:

#include<iostream>
template<class T>
T max5(T ar[])
{
    int n;
    T max = ar[0];
    for (n=1; n<5; n++)
        if (ar[n] > max)
            max = ar[n];
    return max;
}
const int lim = 5;
int main()
{
    using namespace std;
    double ard[lim] = {-3.1, 8.1, -71.1, 34.4, 2.3};
    int ari[lim] = {2, 3, 10, 9, 7};
    double md;
    int mi;
    md = max5(ard);
    mi = max5(ari);
    cout << "Max double = " << md <<endl;
    cout << "Max int = " << mi <<endl;
    return 0;
}

运行结果:

6、编写模板函数maxn(),它将由一个T类型元素组成的数组和一个表示数组元素数目的整数作为参数,并返回数组中最大的元素。在程序对它进行测试,该程序使用一个包含6个int元素的数组和一个包含4个double元素的数组来调用该函数。程序还包含一个具体化,它将char指针数组和数组中的指针数量作为参数,并返回最长的字符串的地址。如果有多个这样的字符串,则返回其中第一个字符串的地址。使用由5个字符串指针组成的数组来测试该具体化。

代码:

#include<iostream>
#include<cstring>
template<class T>
T maxn(T ar[], int n)
{
    int i;
    T max = ar[0];
    for (i=1; i<n; i++)
        if(ar[i] > max)
            max = ar[i];
    return max;
}
template<> const char * maxn(const char * arr[], int n)
{
    const char * max = arr[0];
    int i;
    for (i=1; i<n; i++)
        if(strlen(arr[i]) > strlen(max))
            max = arr[i];
    return max;
}
int main()
{
    using namespace std;
    int ari[6] = {8,4,2,7,10,22};
    double ard[4] = {-3.1, 8.1, -71.1, 34.4};
    const char * char_arr[5] = {
        "hello world!",
        "what your name?",
        "I love you",
        "you are wonderful",
        "hi"
    };
    cout << "The max integer of array is:" << maxn(ari, 6) <<endl;
    cout << "The max double of array is:" << maxn(ard, 4) <<endl;
    cout << "The max string of array is:" << maxn(char_arr, 5) <<endl;
    return 0;
}

运行结果:

7、修改程序清单8.14,使模板函数返回数组元素的总和,而不是显示数组的内容.程序thing的总和以及所有debt的总和.

代码:

#include <iostream>
template <typename T>
T ShowArray (T arr[], int n);
template <typename T>
T ShowArray (T * arr[], int n);
struct debts
{
   char name[50];
   double amount;
};
int main(void)
{
   using namespace std;
   int things[6] = {13, 31, 103, 301, 310, 130};
   struct debts mr_E[3] =
   {
      {"Ima Wolfe",2400.0},
      {"Ura Foxe ",1300.0},
      {"Iby Stout",1800.0}
   };
   double* pd[3];
   for (int i = 0; i < 3; i++)
      pd[i] = &mr_E[i].amount;
   cout<<"Listing Mr. E's counts of things:\n";
   cout << ShowArray(things,6) <<endl;
   cout<<"Listing Mr. E's debts:\n";
   cout << ShowArray(pd,3) <<endl;
   return 0;
}
template <typename T>
T ShowArray (T arr[],int n)
{
   using namespace std;
   T total = 0;
   cout<<"template A\n";
   for (int i = 0; i < n; i++)
      total +=arr[i];
   return total;
}
template <typename T>
T ShowArray (T * arr[], int n)
{
   using namespace std;
   T total = 0;
   cout<< "template B\n";
   for (int i = 0; i < n; i++)
      total += *arr[i];
   return total;
}

运行结果:

时间: 11-02

C++ Primer第八章课后编程题的相关文章

C++ Primer第九章课后编程问题

1. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZ3V1Z2xlMjAxMA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" > 代码: 头文件golf.h代码: const int Len = 40; struct golf { char fullname[Len]; int handicap; }; void setgolf(golf &

POJ C程序设计进阶 编程题#3:运算符判定

编程题#3:运算符判定 来源: POJ (Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩.) 注意: 总时间限制: 1000ms 内存限制: 65536kB 描述 两个整数 a 和 b 运算后得到结果 c.表示为:a ? b = c,其中,?可能是加法 +,减法 -,乘法 *,整除 / 或 取余 %.请根据输入的 a,b,c 的值,确定运算符.如果某种运算成立,则输出相应的运算符,如果任何运算都不成立,则输出 error. 例如: 输入: 3,4,5 输出: er

中国MOOC_面向对象程序设计——Java语言_期末考试编程题_1细胞自动机

期末考试编程题 返回 这是期末考试的编程题 温馨提示: 1.本次考试属于Online Judge题目,提交后由系统即时判分. 2.学生可以在考试截止时间之前提交答案,系统将取其中的最高分作为最终成绩. 1 细胞自动机(30分) 题目内容: 这是细胞自动机的非图形版本.细胞自动机是指在一个二维网格内,每一个网格是一个细胞.每个细胞有活和死两种状态. 初始时刻,有些细胞是活的,有些细胞是死的.自动机的每一步,根据每个细胞周围8个格子内的其他细胞的生存情况决定这个细胞下一步是否存活.具体的规则如下:

京东校招笔试(C++方向)编程题

这次笔试是今年校招我参加的第一次笔试..出了很多状况,基础知识不扎实,导致选择题耽误了太多时间,导致后面的题目没做完,编程题也没有在 时间内写出来,基本没有面试机会了.不过我继续研究第二个编程题,在10几分钟后做了出来. 这个题目具体已经不记得了,但是大概意思还是记得,我们把由4和7组成的数,按小大排序,例如:4 7 44 47 74 77 444 447 474 477 744 747 774 777 他们的序号依次为1,2,3,4.....,题目的输入是每行输入一个整数,可以很大(好像是最大

网易有道内推编程题

[编程题] 洗牌 洗牌在生活中十分常见,现在需要写一个程序模拟洗牌的过程. 现在需要洗2n张牌,从上到下依次是第1张,第2张,第3张一直到第2n张.首先,我们把这2n张牌分成两堆,左手拿着第1张到第n张(上半堆),右手拿着第n+1张到第2n张(下半堆).接着就开始洗牌的过程,先放下右手的最后一张牌,再放下左手的最后一张牌,接着放下右手的倒数第二张牌,再放下左手的倒数第二张牌,直到最后放下左手的第一张牌.接着把牌合并起来就可以了. 例如有6张牌,最开始牌的序列是1,2,3,4,5,6.首先分成两组

2016携程测试实习生笔试编程题

四道大题: 第一道题,是携程网站有一个725*286(具体不记得了)广告区域,能想到的测试类型及方法. 写测试用例——2016年1月1日到2016年3月1日同一订单往返机票立减50 全部功能点. 第二道题,sql语句.(该学sql- -) 第三道题,编程题: 有N个球,M个颜色(M小于等于N),求要想从这N个球里拿出全部(M)个颜色的球,至少需要拿多少个. 思路: 我又是用map实现的,当map的size==M的时候,就说明颜色已经集齐了,计算一个minNum,然后继续扫描,更新minNum 感

搜狐2016研发工程师编程题

1.[编程题]马戏团 搜狐员工小王最近利用假期在外地旅游,在某个小镇碰到一个马戏团表演,精彩的表演结束后发现团长正和大伙在帐篷前激烈讨论,小王打听了下了解到, 马戏团正打算出一个新节目“最高罗汉塔”,即马戏团员叠罗汉表演.考虑到安全因素,要求叠罗汉过程中,站在某个人肩上的人应该既比自己矮又比自己瘦,或相等. 团长想要本次节目中的罗汉塔叠的最高,由于人数众多,正在头疼如何安排人员的问题.小王觉得这个问题很简单,于是统计了参与最高罗汉塔表演的所有团员的身高体重,并且很快找到叠最高罗汉塔的人员序列.

期末考试——编程题#2:能被3,5,7整除的数

编程题#2:能被3,5,7整除的数 来源: POJ(Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩.) 注意: 总时间限制: 1000ms 内存限制: 65536kB 描述 输入一个整数,判断它能否被3,5,7整除,并输出以下信息: 1.能同时被3,5,7整除(直接输出3 5 7,每个数中间一个空格): 2.能被其中两个数整除(输出两个数,小的在前,大的在后.例如:3 5或者 3 7或者5 7,中间用空格分隔) 3.能被其中一个数整除(输出这个除数) 4.不能被任

挑战编程题(三)

接 挑战编程题(二)http://www.cnblogs.com/qiange/p/5090588.html 题目: 有两个非负数的链表,每个链表都反序的存储一个多位数字的每一位,(例如:链表2->4->3  数字342),现在求两个链表数字的相加,求和的链表. 例如: Input: (2 -> 4 -> 3) + (5 -> 6 -> 4) Output: 7 -> 0 -> 8 /** * Definition for singly-linked lis

POJ C++程序设计 编程题#10:输出指定结果二

编程题#10:输出指定结果二 来源: 北京大学在线程序评测系统POJ (Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩.) 总时间限制: 1000ms 内存限制: 1024kB 描述 通过填空使得程序输出的结果符合下面的要求. #include <iostream> #include <map> using namespace std; // 在此处补充你的代码 int A::count = 0; void func(B b) { } int mai