《C++ Primer Plus》(第6版)第6章编程练习

news2025/1/20 5:53:55

《C++ Primer Plus》(第6版)第6章编程练习

  • 《C++ Primer Plus》(第6版)第6章编程练习
    • 1. 大小写转换
    • 2. 平均值
    • 3. 菜单
    • 4. 成员
    • 5. 收入所得税
    • 6. 捐款
    • 7. 统计单词
    • 8. 统计文件字符数
    • 9. 重写编程练习6

《C++ Primer Plus》(第6版)第6章编程练习

1. 大小写转换

编写一个程序,读取键盘输入,直到遇到@符号为止,并回显输入(数字除外),同时将大写字符转换为小写,将小写字符转换为大写(别忘了cctype函数系列)。

代码:

#include <iostream>
#include <cctype>
using namespace std;

int main()
{
    char c;

    cout << "Enter text for analysis(enter @ to quit):\n";
    while (cin >> c && c != '@')
    {
        if (islower(c))
            c = toupper(c);
        else if (isupper(c))
            c = tolower(c);
        if (!isdigit(c))
            cout << c;
    }
    cout << "Done!\n";

    system("pause");
    return 0;
}

在这里插入图片描述

2. 平均值

编写一个程序,最多将10个donation值读入到一个double数组中(如果您愿意,也可使用模板类array)。程序遇到非数字输入时将结束输入,并报告这些数字的平均值以及数组中有多少个数字大于平均值。

代码:

#include <iostream>
#include <array>
using namespace std;
#define ArrSize 10

int main(void)
{
    array<double, ArrSize> donation;

    cout << "Enter the elements you want to exist in the array "
         << "( a non number input to terminate):" << endl;
    int i = 0;
    double sum = 0;
    int elem = 0;
    int count = 0;
    while (i < ArrSize && cin >> donation[i])
    {
        elem++;
        sum += donation[i];
        i++;
    }
    double average = sum / elem;
    for (i = 0; i < ArrSize; i++)
    {
        if (donation[i] > average)
            count++;
    }
    cout << "average = " << average << endl;
    cout << count << " numbers greater than average.\n";

    system("pause");
    return 0;
}

运行结果:

在这里插入图片描述

3. 菜单

编写一个菜单驱动程序的雏形。该程序显示一个提供4个选项的菜单——每个选项用一个字母标记。如果用户使用有效选项之外的字母进行响应,程序将提示用户输入一个有效的字母,直到用户这样做为止。然后,该程序使用一条switch语句,根据用户的选择执行一个简单操作。该程序的运行情况如下:

Please enter one of the following choices :
c) carnivore       p) pianist
t) tree                 g) game
f
Please enter a c, p, t, or g: q

Please enter a c, p,t, or g: t

A maple is a tree.

代码:

#include <iostream>
using namespace std;
int main()
{
    char ch;

    cout << "Please enter one of the following choices:" << endl;
    cout << "c) carnivore           p) pianist" << endl;
    cout << "t) tree                g) game" << endl;

    while (cin >> ch)
    {
        switch (ch)
        {
        case 'c':
            cout << "A tiger is a carnivore." << endl;
            break;
        case 'p':
            cout << "Langlang is a pianist." << endl;
            break;
        case 't':
            cout << "A maple is a tree." << endl;
            break;
        case 'g':
            cout << "Golf is a game." << endl;
            break;
        default:
            cout << "Please enter a c, p, t, or g: ";
        }
    }

    system("pause");
    return 0;
}

运行结果:

在这里插入图片描述

4. 成员

加入 Benevolent Order of Programmer后,在 BOP大会上,人们便可以通过加入者的真实姓名、头衔或秘密BOP姓名来了解他(她)。请编写一个程序,可以使用真实姓名、头衔、秘密姓名或成员偏好来列出成员。编写该程序时,请使用下面的结构:

// Benevolent Order of Programmers name structure
struct bop {
char fullname [strsize] ;// real name

char title[strsize] ;         // job title
char bopname [strsize] ;  //secret BOP name
int preference;                //0 = fullname,1 = title, 2 = bopname);

该程序创建一个由上述结构组成的小型数组,并将其初始化为适当的值。另外,该程序使用一个循环,让用户在下面的选项中进行选择:

a. display by name         b. display by title
c. display by bopname      d. display by preference
q. quit

注意,“display by preference”并不意味着显示成员的偏好,而是意味着根据成员的偏好来列出成员。例如,如果偏好号为1,则选择d将显示程序员的头衔。该程序的运行情况如下:

Benevolent order of Programmers Report
a. display by name         b. display by title
c. display by bopname      d. display by preference
q. quit
Enter your choice: a
wimp Macho
Raki Rhodes
Celia Laiter
Hoppy Hipman
Pat Hand
Next choice: d
wimp Macho
Junior Programmer
MIPS
Analyst Trainee
LOOFY
Next choice: q
Bye!

代码:

#include <iostream>
using namespace std;
#define LEN 5
#define strsize 20
// Benevolent Order of Programmers name structure
struct bop
{
    char fullname[strsize]; // real name
    char title[strsize];    // job title
    char bopname[strsize];  // secret BOP name
    int preference;         // 0 = fullname,1 = title, 2 = bopname);
};

void display_by_name(bop *);
void display_by_title(bop *);
void display_by_bopname(bop *);
void display_by_preference(bop *);

int main()
{
    char ch;
    bop member[LEN] =
        {
            {"Wimp Mache", "BOSS", "AS", 0},
            {"Raki Rhodes", "Junior Programmer", "MA", 1},
            {"Celia Laiter", "Manager", "MIPS", 2},
            {"Hoppy Hipman", "Analyst Trainee", "CL", 1},
            {"Pat Hand", "Student", "LOOPY", 2}};

    cout << "Benevolent Order of Programmers Report\n";
    cout << "a. display by name     b. display by title\n";
    cout << "c. display by bopname  d. display by preference\n";
    cout << "q. quit\n";
    cout << "Enter your choice: ";
    while (cin >> ch && ch != 'q')
    {
        switch (ch)
        {
        case 'a':
            display_by_name(member);
            break;
        case 'b':
            display_by_title(member);
            break;
        case 'c':
            display_by_bopname(member);
            break;
        case 'd':
            display_by_preference(member);
            break;
        }
        cout << "Next choice: ";
    }
    cout << "Bye!\n";

    system("pause");
    return 0;
}
void display_by_name(bop *b)
{
    for (int i = 0; i < LEN; i++)
        cout << b[i].fullname << endl;
}
void display_by_title(bop *b)
{
    for (int i = 0; i < LEN; i++)
        cout << b[i].title << endl;
}
void display_by_bopname(bop *b)
{
    for (int i = 0; i < LEN; i++)
        cout << b[i].bopname << endl;
}
void display_by_preference(bop *b)
{
    for (int i = 0; i < LEN; i++)
    {
        switch (b[i].preference)
        {
        case 0:
            cout << b[i].fullname << endl;
            break;
        case 1:
            cout << b[i].title << endl;
            break;
        case 2:
            cout << b[i].bopname << endl;
            break;
        }
    }
}

运行结果:

在这里插入图片描述

5. 收入所得税

在 Ncutronia王国,货币单位是tvarp,收入所得税的计算方式如下:

5000 tvarps:不收税
5001~15000 tvarps:10%
15001~35000 tvarps:15%
35000 tvarps 以上:20%

例如,收入为38000 tvarps 时,所得税为5000 × 0.00 + 10000 × 0.10 +20000 × 0.15 + 3000 × 0.20,即4600 tvarps。请编写一个程序,使用循环来要求用户输入收入,并报告所得税。当用户输入负数或非数字时,循环将结束。

代码:

#include <iostream>
using namespace std;
#define RATE1 0.10
#define RATE2 0.15
#define RATE3 0.20
double cal_tax(int);
int main()
{
    int income;
    double tax;
    cout << "Enter your income(enter negative number or q to quit): ";
    while (cin >> income && income >= 0)
    {
        cout << "your tax is " << cal_tax(income) <<".\n";
        cout << "Enter your income: ";
    }

    system("pause");
    return 0;
}
double cal_tax(int x)
{
    double tax;
    if (x <= 5000)
        tax = 0.0;
    else if (x <= 15000)
        tax = RATE1 * (x - 5000);
    else if (x <= 35000)
        tax = RATE1 * (15000 - 5000) + RATE2 * (x - 15000);
    else
        tax = RATE1 * (15000 - 5000) + RATE2 * (35000 - 15000) + RATE3 * (x - 35000);
    return tax;
}

运行结果:

在这里插入图片描述

6. 捐款

编写一个程序,记录捐助给“维护合法权利团体”的资金。该程序要求用户输入捐献者数目,然后要求用户输入每一个捐献者的姓名和款项。这些信息被储存在一个动态分配的结构数组中。每个结构有两个成员:用来储存姓名的字符数组(或string对象)和用来存储款项的double成员。读取所有的数据后,程序将显示所有捐款超过10000的捐款者的姓名及其捐款数额。该列表前应包含一个标题,指出下面的捐款者是重要捐款人(Grand Patrons)。然后,程序将列出其他的捐款者,该列表要以Patrons开头。如果某种类别没有捐款者,则程序将打印单词“none”。该程序只显示这两种类别,而不进行排序。

代码:

#include <iostream>
#include <cstring>
using namespace std;
struct Donor
{
    string name;
    double money;
};

void showGrand(Donor *, int);
void showOther(Donor *, int);

int main()
{
    int num = 0;

    cout << "How many donors are there? ";
    cin >> num;
    cin.get(); // 清除缓存

    Donor *donor = new Donor[num];

    for (int i = 0; i < num; i++)
    {
        cout << "Please enter the " << i + 1 << "-th name: ";
        getline(cin, donor[i].name);
        cout << "Please enter the " << i + 1 << "-th money: ";
        cin >> donor[i].money;
        cin.get();
    }
    cout << "Grand Patrons:\n";
    showGrand(donor, num);
    cout << "Patrons:\n";
    showOther(donor, num);

    system("pause");
    return 0;
}

void showGrand(Donor *d, int num)
{
    int count = 0;

    for (int j = 0; j < num; j++)
    {
        if (d[j].money > 10000)
        {
            cout << d[j].name << "\t" << d[j].money << endl;
            count++;
        }
    }
    if (count == 0)
        cout << "none\n";
}

void showOther(Donor *d, int num)
{
    int count = 0;
    for (int j = 0; j < num; j++)
    {
        if (d[j].money <= 10000)
        {
            cout << d[j].name << "\t" << d[j].money << endl;
            count++;
        }
    }
    if (count == 0)
        cout << "none\n";
}

运行结果:

在这里插入图片描述

7. 统计单词

编写一个程序,它每次读取一个单词,直到用户只输入q。然后,该程序指出有多少个单词以元音打头,有多少个单词以辅音打头,还有多少个单词不属于这两类。为此,方法之一是,使用isalpha( )来区分以字母和其他字符打头的单词,然后对于通过了isalpha()测试的单词,使用if或switch语句来确定哪些以元音打头。该程序的运行情况如下:

Enter words (q to quit) :
The 12 awesome oxen ambled
quietly across 15 meters of lawn. q
5 words beginning with vowels
4 words beginning with consonants
2 others

代码:

#include <iostream>
#include <cstring>
#include <cctype>
using namespace std;

#define ArrSize 30

int main(void)
{
    char str[ArrSize];
    int count_other = 0, count_vowel = 0, count_consonant = 0;

    cout << "Enter words(q to quit) :" << endl;
    while (cin >> str)
    {
        if (strcmp(str, "q") == 0)
            break;
        char ch = str[0];
        if (isalpha(ch))
        {

            switch (ch)
            {
            case 'a':
            case 'e':
            case 'i':
            case 'o':
            case 'u':
                count_vowel++;
                break;
            default:
                count_consonant++;
            }
        }
        else
            count_other++;
    }
    cout << count_vowel << " words beginning with vowels\n";
    cout << count_consonant << " words beginning with consonants\n";
    cout << count_other << " others\n";

    system("pause");
    return 0;
}

运行结果:

在这里插入图片描述

8. 统计文件字符数

编写一个程序,它打开一个文件文件,逐个字符地读取该文件,直到到达文件末尾,然后指出该文件中包含多少个字符。

代码:

#include <iostream>
#include <fstream>
#include <cstdlib>
using namespace std;

#define SIZE 60

int main()
{
    char filename[SIZE];
    ifstream inFile;

    cout << "Enter name of data file:";
    cin.getline(filename, SIZE);
    inFile.open(filename);
    if (!inFile.is_open())
    {
        cout << "Could not open the file " << filename << endl;
        cout << "Program terminating." << endl;
        exit(EXIT_FAILURE);
    }

    int count = 0;
    char ch;

    inFile >> ch;
    while (inFile.good())
    {
        count++;
        inFile >> ch;
        // cout << ch;
    }
    if (inFile.eof())
        cout << "End of file reached." << endl;
    else if (inFile.fail())
        cout << "Input terminated by data mismatch." << endl;
    else
        cout << "Input terminated for unknown reason." << endl;

    cout << "A total of " << count << " characters were read." << endl;
    inFile.close();

    system("pause");
    return 0;
}

运行结果:

在这里插入图片描述

9. 重写编程练习6

完成编程练习6,但从文件中读取所需的信息。该文件的第一项应为捐款人数,余下的内容应为成对的行。在每一对中,第一行为捐款人姓名,第二行为捐款数额。即该文件类似于下面;

4
sam stone
2000
Freida Flass
100500
Tammy Tubbs
5000
Rich Raptor
55000

代码:

#include <iostream>
#include <cstring>
#include <fstream>
using namespace std;

#define SIZE 30

struct Donor
{
    string name;
    double money;
};

void showGrand(Donor *, int);
void showOther(Donor *, int);

int main()
{
    char fileName[SIZE];
    ifstream infile;
    int num = 0;

    cout << "Enter the filename: ";
    cin.getline(fileName, SIZE);
    infile.open(fileName);
    if (!infile.is_open())
    {
        cout << "Can't open file " << fileName << endl;
        cout << "program terminating." << endl;
        exit(EXIT_FAILURE);
    }
    infile >> num;
    infile.get(); // 清除缓存

    Donor *donor = new Donor[num];

    for (int i = 0; i < num; i++)
    {
        getline(infile, donor[i].name);
        infile >> donor[i].money;
        infile.get(); // 清除缓存
    }
    cout << "Grand Patrons:\n";
    showGrand(donor, num);
    cout << "Patrons:\n";
    showOther(donor, num);

    system("pause");
    return 0;
}

void showGrand(Donor *d, int num)
{
    int count = 0;

    for (int j = 0; j < num; j++)
    {
        if (d[j].money > 10000)
        {
            cout << d[j].name << "\t" << d[j].money << endl;
            count++;
        }
    }
    if (count == 0)
        cout << "none\n";
}

void showOther(Donor *d, int num)
{
    int count = 0;
    for (int j = 0; j < num; j++)
    {
        if (d[j].money <= 10000)
        {
            cout << d[j].name << "\t" << d[j].money << endl;
            count++;
        }
    }
    if (count == 0)
        cout << "none\n";
}

运行结果:

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/378155.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

taobao.top.secret.appkey.bill.detail( 服务商解密账单查询 )

&#xffe5;免费不需用户授权 服务商解密账单查询,分页返回所有店铺的账单&#xff0c;每个店铺每天仅包含两条数据&#xff0c;当天产生的号租费 和 当天产生的通话费&#xff0c;仅对90天内的账单提供SLA保障。查询账单详情请使用taobao.top.secret.bill.detail接口。 公共参…

计算机的发展

个人简介&#xff1a;云计算网络运维专业人员&#xff0c;了解运维知识&#xff0c;掌握TCP/IP协议&#xff0c;每天分享网络运维知识与技能。个人爱好: 编程&#xff0c;打篮球&#xff0c;计算机知识个人名言&#xff1a;海不辞水&#xff0c;故能成其大&#xff1b;山不辞石…

云打包苹果证书生成、上架和应用截屏攻略

在使用apicloud或hbuilderx这些跨端的开发工具开发移动应用的时候&#xff0c;假如是打包ios应用&#xff0c;是需要生成苹果证书、证书profile文件&#xff0c;和对应用上架的。首先要普及一个概念&#xff0c;苹果的应用是无法像安卓那样挂在自己的服务器上下载直接安装就可以…

C++ STL:迭代器 Iterator

文章目录1、迭代器的类型2、traitsiterator_traitstype_traits泛化的指针&#xff0c;容器与算法的桥梁。提供一种方法&#xff0c;按照一定顺序访问一个聚合对象中各个元素&#xff0c;而又不暴露该对象的内部表示。既能对容器进行遍历&#xff0c;又可以对外隐藏容器的底层实…

谷歌邮箱账号不会注册?注册失败?这份完美注册教程请收好

谷歌邮箱相信大家都不陌生吧&#xff0c;无论是用于发送和接收邮件&#xff0c;还是用于在国外网站注册&#xff0c;很多人都离不开谷歌邮箱。甚至&#xff0c;一些网站直接提供谷歌邮箱登录选项。这就是为什么很多跨境人想要注册谷歌邮箱的原因。 但是&#xff0c;大部分网友都…

Java学习之路002——面向对象编程

【说明】部分内容来源于网络&#xff0c;如有冲突&#xff0c;请联系作者删除。 一、面向对象编程(OOP) 2.1 对象和类的关系 2.2 面向对象的特征 2.2.1 封装 2.2.2 继承 2.2.3 多态 3、抽象 使用abstract关键字修饰的类或者方法 定义抽象类(使用abstract) // 1、定义抽象方法…

计数排序.

1.动图演示&#xff1a; 2.代码示例&#xff1a; package test1;import java.util.Arrays;public class Test3 {public static void main(String[] args) {int[] nums new int[]{1, 2, 1, 4, 52, 1, 4};int[] arr count_sort(nums, getMax(nums));for (int i : arr) {System…

spring boot 配合element ui vue实现表格的批量删除(前后端详细教学,简单易懂,有手就行)

目录 一.前言&#xff1a; 二. 前端代码&#xff1a; 2.1.element ui组件代码 2.2删除按钮 2.3.data 2.4.methods 三.后端代码&#xff1a; 一.前言&#xff1a; 研究了其他人的博客&#xff0c;找到了一篇有含金量的&#xff0c;进行了部分改写实现前后端分离&#xff0…

【Python实战】爬虫教程千千万,一到实战全完蛋?今天手把手教你一键采集某网站图书信息数据啦~排名第一的竟是...(爬虫+数据可视化)

前言 ​一本本书&#xff0c;是一扇扇窗&#xff0c;为追求知识的人打开认知世界的窗口 一本本书&#xff0c;是一双双翅膀&#xff0c;让追求理想的人张开翅膀翱翔 所有文章完整的素材源码都在&#x1f447;&#x1f447; 粉丝白嫖源码福利&#xff0c;请移步至CSDN社区或文末…

机器学习的特征归一化Normalization

为什么需要做归一化&#xff1f; 为了消除数据特征之间的量纲影响&#xff0c;就需要对特征进行归一化处理&#xff0c;使得不同指标之间具有可比性。对特征归一化可以将所有特征都统一到一个大致相同的数值区间内。 为了后⾯数据处理的⽅便&#xff0c;归⼀化可以避免⼀些不…

Pycharm和跳板机 连接内网服务器

Pycharm和跳板机 连接内网服务器 建立配置文件 本地配置 .ssh 文件夹下配置 config 文件 Host jumpHostName xxxPort 22User xxxServerAliveInterval 30IdentityFile C:\Users\15284\.ssh\id_rsa # 通过密钥连接Host server # 同样&#xff0c;任意名字&#xff0c;随…

vxe自定义表头设置+前端本地数据存储

业务要求 支持拖动排序&#xff0c;按现有内容排序支持显示/隐藏&#xff0c;默认全部显示列表增加顶部格线&#xff0c;用户可以自己调整列宽设置内容仅对该账号有效&#xff0c;前端存储 最终实现的效果图 哪些改动 静态表格改动态表格 table > grid vxe-grid 高级表格…

一文深度解读音视频行业技术发展历程

从1948年的香农定律&#xff0c;到音视频的今天。IMMENSE、36氪&#xff5c;作者 北京时间2月28日凌晨&#xff0c;FIFA年度颁奖典礼在巴黎举行。梅西荣膺年度最佳球员&#xff0c;斯卡洛尼当选年度最佳男足主帅&#xff0c;马丁内斯荣获年度最佳男足门将&#xff01;阿根廷因…

自动售卖机的类型和工作流程分析

线上经济的崛起提高了人们的生活品质&#xff0c;促进了我国市场经济的发展。随着互联网的快速发展&#xff0c;线上经济资源已经饱和&#xff0c;线上和线下资源整合已经成为市场经济发展的方向&#xff0c;而自动售卖机正是线上和线下经济发展的连接纽带。 自动售卖机作为无人…

3.查找算法:顺序查找和二分查找

查找查找&#xff0c;是指在一些数据元素中&#xff0c;通过一定的方法找出与给定关键字相同的数据元素的过程。列表查找&#xff08;线性表查找&#xff09;&#xff1a;从列表中查找指定元素输入&#xff1a;列表&#xff0c;待查找元素输出&#xff1a;元素下标&#xff08;…

多线程 随便起的

进程&#xff1a;进程可以看成程序执行的一个实例。进程是系统资源分配的独立实体&#xff0c;每个进程都拥有独立的地址空间。一个进程无法访问另一个进程的变量和数据结构如果想让-一个进程访问另一个进程的资源&#xff0c;需要使用进程间通信&#xff0c;比如管道&#xff…

LAMP项目部署实战1

一、说明&#xff1a; LAMP&#xff1a;Linux Apache MySQL PHP Apache&#xff1a; Apache是世界使用排名第一的Web服务器软件。主要用于接收用户的请求&#xff0c;处理业务逻辑&#xff0c;返回结果给客户端&#xff08;浏览器&#xff09;。 PHP&#xff1a;一种专门…

SQL 层功能改进 - lookupJoin 的优化

一、传统 join 算法lookupJoin 是 join 查询的一种&#xff0c;传统 join 算法为&#xff1a;1. 遍历 A 表&#xff0c;读取一条数据 r2. 遍历 B 表&#xff0c;对于每条数据&#xff0c;与 r 进行 join 操作3. 重复 1、2 操作&#xff0c;直到 A 表遍历完所有数据二、lookupJo…

在 WIndows 下安装 Apache Tinkerpop (Gremlin)

一、安装 JDK 首先安装 Java JDK&#xff0c;这个去官网下载即可&#xff0c;我下载安装的 JDK19&#xff08;jdk-19_windows-x64_bin.msi&#xff09;&#xff0c;细节不赘述。 二、去 Tinkerpop 网站下载 Gremlin 网址&#xff1a;https://tinkerpop.apache.org/ 点击下面…

用cpolar发布本地的论坛网站 1

网页论坛向来是个很神奇的地方&#xff0c;曾经的天涯论坛和各种BBS&#xff0c;大家聚在在一起讨论某个问题&#xff0c;也能通过论坛发布想法&#xff0c;各种思维碰撞在一起&#xff0c;发生很多有趣的故事&#xff0c;也产生了很多流传一时的流行语录。当然&#xff0c;如果…