C++第九章编程练习答案

题一

头文件

test9_1.h

复制代码
#ifndef TEST9_1_H_
#define TEST9_1_H_
const int Len = 40;
struct golf
{
    char fullname[Len];
    int handicap;
};

void setgolf(golf &g, const char *name, int hc);
// 赋值函数

int setgolf(golf &g);
// 按输入赋值

void handicap(golf &g, int hc);
// 对handicap重新赋值

void showgolf(const golf &g);
#endif

源文件

复制代码
#include <iostream>
#include "test9_1.h"
#include <cstring>
using namespace std;

void setgolf(golf &g, const char *name, int hc)
{
    strcpy(g.fullname, name);
    g.handicap = hc;
}

int setgolf(golf &g)
{
    cout << "Enter the fullname :";
    cin.get(g.fullname, Len);
    cout << "Enter the handicap: ";
    cin >> g.handicap;
    cin.get();
    if (g.fullname[0] == '\0')
        return 0;
    else
        return 1;
}

void handicap(golf &g, int hc)
{
    g.handicap = hc;
}

void showgolf(const golf &g)
{
    if (g.fullname[0] != '\0')
    {
        cout << "fullname: " << g.fullname << endl;
        cout << "handicap: " << g.handicap << endl;
    }
}

源代码

复制代码
#include <iostream>
#include "test9_1.h"
using namespace std;
int main()
{
    golf ann;
    setgolf(ann, "Ann Birdfree", 24);
    showgolf(ann);

    golf *golfarr = new golf[3];
    for (int i = 0; i < 3 && setgolf(golfarr[i]); i++)
    {
    }
    for (int i = 0; i < 3; i++)
        showgolf(golfarr[i]);
    delete[] golfarr;
    return 0;
}

题二

复制代码
// static.cpp--using a static local variable
#include <iostream> //constants
#include <string>
#include <cstring>
using namespace std;
// const int ArSize = 10;
//  function prototype
void strcount(const string str);
int main()
{
    // char input[ArSize];
    string input;
    char next;
    cout << "Enter a line:\n";
    getline(cin, input);
    while (input != "")
    {
        strcount(input);
        cout << "Enter next line(empty line to quit);\n";
        getline(cin, input);
    }
    cout << "Bye\n";
    return 0;
}
void strcount(const string str)
{
    using namespace std;
    static int total = 0;
    int count = 0;
    // static local variable
    // automatic local variable
    cout << "\"" << str << "\"contains \n";
    count = str.size();
    total += count;
    cout << count << " characters\n";
    cout << total << " characters total\n";
}

题三

方法一

复制代码
#include <iostream>
#include <new>
#include <cstring>
const int BUF = 512;
const int N = 5;
char buffer[BUF];
struct chaff
{
    char dross[20];
    int salg;
};
int main()
{
    using namespace std;
    chaff *array1 = new (buffer) chaff[2];
    for (int i = 0; i < 2; i++)
    {
        cout << "dross" << i + 1 << ": ";
        cin.getline(array1[i].dross, 20);
        cout << "salg" << i + 1 << ":";
        cin >> array1[i].salg;
        cin.get();
    }

    for (int i = 0; i < 2; i++)
    {
        cout << "dross" << i + 1 << ": " << array1[i].dross << endl;

        cout << "salg" << i + 1 << ": " << array1[i].salg << endl;
    }
    return 0;
}

方法二

复制代码
#include <iostream>
#include <new>
#include <cstring>
const int BUF = 512;
struct chaff
{
    char dross[20];
    int salg;
};
int main()
{
    using namespace std;
    char *buffer = new char[BUF];
    chaff *array1 = new (buffer) chaff[2];
    for (int i = 0; i < 2; i++)
    {
        cout << "dross" << i + 1 << ": ";
        cin.getline(array1[i].dross, 20);
        cout << "salg" << i + 1 << ":";
        cin >> array1[i].salg;
        cin.get();
    }

    for (int i = 0; i < 2; i++)
    {
        cout << "dross" << i + 1 << ": " << array1[i].dross << endl;

        cout << "salg" << i + 1 << ": " << array1[i].salg << endl;
    }
    delete buffer;
    return 0;
}

题四

头文件

复制代码
#ifndef TEST9_4_H_
#define TEST9_4_H_
namespace SALES
{
    const int QUARTERS = 4;
    struct Sales
    {
        double sales[QUARTERS];
        double average;
        double max;
        double min;
    };

    void setSales(Sales &s, const double ar[], int n);

    void setSales(Sales &s);

    void showSales(const Sales &s);
}
#endif

源代码

复制代码
#include "test9_4.h"
#include <iostream>
using namespace std;

void SALES::setSales(Sales &s, const double ar[], int n)
{
    double sum;
    s.max = ar[0];
    s.min = ar[0];
    // int length = sizeof(ar) / sizeof(double);
    for (int i = 0; i < QUARTERS; i++)
    {
        if (i < n)
        {
            sum += ar[i];
            s.sales[i] = ar[i];
            if (ar[i] > s.max)
                s.max = ar[i];
            if (ar[i] < s.min)
                s.min = ar[i];
        }
        else
            s.sales[i] = 0;
    }
    s.average = sum / n;
}

void SALES::setSales(Sales &s)
{
    s.max = 0;
    s.min = 999999;
    for (int i = 0; i < QUARTERS; i++)
    {
        cout << "Enter " << i + 1 << "-th quarter sales:";
        cin >> s.sales[i];
        s.average += s.sales[i];
        if (s.sales[i] > s.max)
            s.max = s.sales[i];
        if (s.sales[i] < s.min)
            s.min = s.sales[i];
    }
    s.average /= QUARTERS;
}
void SALES::showSales(const Sales &s)
{
    for (int i = 0; i < QUARTERS; i++)
        cout << i + 1 << "-th quarter sales:" << s.sales[i] << endl;

    cout << "average :" << s.average << endl;
    cout << "max :" << s.max << endl;
    cout << "min :" << s.min << endl;
}

源代码

复制代码
#include <iostream>
#include "test9_4.h"
using namespace std;
using namespace SALES;
int main()
{
    Sales FirstYear;
    double earning[3] = {10, 20, 30};
    setSales(FirstYear, earning, 3);
    showSales(FirstYear);

    Sales SecondYear;
    setSales(SecondYear);
    showSales(SecondYear);
    return 0;
}
相关推荐
上单带刀不带妹2 分钟前
手写 Vue 中虚拟 DOM 到真实 DOM 的完整过程
开发语言·前端·javascript·vue.js·前端框架
Kaltistss22 分钟前
98.验证二叉搜索树
算法·leetcode·职场和发展
im_AMBER23 分钟前
学习日志05 python
python·学习
知己如祭26 分钟前
图论基础(DFS、BFS、拓扑排序)
算法
mit6.82435 分钟前
[Cyclone] 哈希算法 | SIMD优化哈希计算 | 大数运算 (Int类)
算法·哈希算法
c++bug38 分钟前
动态规划VS记忆化搜索(2)
算法·动态规划
哪 吒40 分钟前
2025B卷 - 华为OD机试七日集训第5期 - 按算法分类,由易到难,循序渐进,玩转OD(Python/JS/C/C++)
python·算法·华为od·华为od机试·2025b卷
-凌凌漆-43 分钟前
【Qt】QStringLiteral 介绍
开发语言·qt
程序员爱钓鱼43 分钟前
Go语言项目工程化 — 常见开发工具与 CI/CD 支持
开发语言·后端·golang·gin