Chapter Review

1

a. char actors[30];

b. short betsie[100];

c. float chunk[13];

d. long double dipsea[64];

2

a. array<char, 30> actors;

b. array<short, 100> betsie;

c. array<float, 13> chunk;

d. array<long double, 64> dipsea;

3

int oddly[5] = {1, 3, 5, 7, 9};

4

int even = oddly[0] + oddly[4];

5

cout << ideas[1] << "\n"; // or << endl;

6

char lunch[13] = "cheeseburger"; // number of characters + 1
or
char lunch[] = "cheeseburger"; // let the compiler count elements

7

string lunch = "Waldorf Salad";
or, if you don't have a using directive,
std::string lunch = "Waldorf Salad";

8

struct fish
{
    char kind[20];
    int weight;
    float length;
};

9

fish petes =
{
    "trout",
    12,
    26.66
}

10

enum Response {No, Yes, Maybe};

11

double * pd = &ted;
cout << *pd << "\n";

12

float * pf = treacle; // or = &treacle[0]
cout << pf[0] << " " << pf[9] << "\n";
// or use *pf and *(pf + 9)

13

This assumes that the iostream and vector header files have been included and that there is a using directive:

unsigned int size;
cout << "Enter a positive integer: ";
cin >> size;
int * dyn = new int [size];
vector<int> dv(size);

14

Yes, it is valid. The expression "Home of the jolly bytes" is a string constant; hence it evaluates as the address of the beginning of the string. The cout object interprets the address of a char as an invitation to print a string, but the type cast (int *) converts the address to type pointer-to-int, which is then printed as an address. In short, the statement prints the address of the string, assuming the int type is wide enough to hold an address.

15

struct fish
{
    char kind[20];
    int weight;
    float length;
};

fish * pole = new fish;
cout << "Enter kind of fish: ";
cin >> pole -> kind;

16

Using cin >> address causes a program to skip over whitespace until it finds non-whitespace. It then reads characters until it encounters whitespace again. Thus, it will skip over the newline following the numeric input, avoiding that problem. On the other hand, it will read just a single word, not an entire line.

17

#include <string>
#include <vector>
#include <array>
const int Str_num {10}; // or = 10
...
std::vector<std::string> vstr(Str_num);
std::array<std::string, Str_num> astr;

Programming Exercises

1

#include <iostream>

int main()
{
    using namespace std;

    cout << "What is your first name? ";
    char first_name[20];
    cin.getline(first_name, 20);

    cout << "What is your last name? ";
    char last_name[20];
    cin.getline(last_name, 20);

    cout << "What letter grade do you deserve? ";
    char grade;
    cin.get(grade);

    cout << "What is your age? ";
    int age;
    cin >> age;

    cout << "Name: " << last_name << ", " << first_name << endl
         << "Grade: " << grade << "\n"
         << "Age: " << age << endl;

    return 0;
}

2

#include <iostream>
#include <string>

int main()
{
    using namespace std;

    string name;
    string dessert;

    cout << "Enter your name: \n";
    getline(cin, name);
    cout << "Enter your favorite dessert: \n";
    getline(cin, dessert);
    cout << "I have some delicious " << dessert;
    cout << " for you, " << name << ".\n";

    return 0;
}

3

#include <iostream>
#include <cstring>

int main()
{
    using namespace std;

    char first_name[20], last_name[20];
    char combined[40];

    cout << "Enter your first name: ";
    cin >> first_name;
    cout << "Enter your favorite last name: ";
    cin >> last_name;

    strcpy(combined, last_name);
    strcat(combined, ", ");
    strcat(combined, first_name);
    cout << "Here's the information in a single string: " << combined << endl;

    return 0;
}

4

#include <iostream>
#include <string>

int main()
{
    using namespace std;

    string first_name, last_name, combined;

    cout << "Enter your first name: ";
    cin >> first_name;
    cout << "Enter your favorite last name: ";
    cin >> last_name;

    combined = last_name + ", " + first_name;
    cout << "Here's the information in a single string: " << combined << endl;

    return 0;
}

5

#include <iostream>
#include <string>

struct CandyBar
{
    std::string brand;
    float weight;
    int calories;
};

int main()
{
    using namespace std;

    CandyBar snack = {"Mocha Munch", 2.3, 350};

    cout << "Brand: " << snack.brand << "\nWeight: " << snack.weight
         << "\nCalories = " << snack.calories << endl;

    return 0;
}

6

#include <iostream>
#include <string>

struct CandyBar
{
    std::string brand;
    float weight;
    int cal;
};

int main()
{
    using namespace std;

    CandyBar snack[3] = {{"Mocha Munch", 2.3, 350}, {"Wei Long", 0.5, 222}, {"crisps", 1.0, 500}};

    cout << "Brand: " << snack[0].brand << endl
         << "Weight: " << snack[0].weight << endl
         << "Calories: " << snack[0].cal << endl << endl;

    cout << "Brand: " << snack[1].brand << endl
         << "Weight: " << snack[1].weight << endl
         << "Calories: " << snack[1].cal << endl << endl;

    cout << "Brand: " << snack[2].brand << endl
         << "Weight: " << snack[2].weight << endl
         << "Calories: " << snack[2].cal << endl << endl;

    return 0;
}

7

#include <iostream>
#include <string>

using namespace std;

struct Pizza
{
    string company;
    float diameter;
    float weight;
};

int main()
{
    Pizza piz;

    cout << "Enter the pizza's company: ";
    getline(cin, piz.company);
    cout << "Enter the pizza's diameter(in CM): ";
    cin >> piz.diameter;
    cout << "Enter the pizza's weight(in Kg): ";
    cin >> piz.weight;

    cout << "Company: " << piz.company << endl;
    cout << "Diameter: " << piz.diameter << " CM" << endl;
    cout << "Weight: " << piz.weight << " Kg" << endl;

    return 0;
}

8

#include <iostream>
#include <string>

using namespace std;

struct Pizza
{
    string company;
    float diameter;
    float weight;
};

int main()
{
    Pizza * piz = new Pizza;

    cout << "Enter the pizza's company: ";
    getline(cin, piz -> company);
    cout << "Enter the pizza's diameter(in CM): ";
    cin >> piz -> diameter;
    cout << "Enter the pizza's weight(in Kg): ";
    cin >> piz -> weight;

    cout << "Company: " << piz -> company << endl;
    cout << "Diameter: " << piz -> diameter << " CM" << endl;
    cout << "Weight: " << piz -> weight << " Kg" << endl;

    return 0;
}

9

#include <iostream>
#include <string>

struct CandyBar
{
    std::string brand;
    float weight;
    int cal;
};

int main()
{
    using namespace std;

    CandyBar * snack = new CandyBar[3];
    snack[0] = {"Mocha Munch", 2.3, 350};
    snack[1] = {"Wei Long", 0.5, 222};
    snack[2] = {"crisps", 1.0, 500};

    cout << "Brand: " << snack[0].brand << endl
         << "Weight: " << snack[0].weight << endl
         << "Calories: " << snack[0].cal << endl << endl;

    cout << "Brand: " << snack[1].brand << endl
         << "Weight: " << snack[1].weight << endl
         << "Calories: " << snack[1].cal << endl << endl;

    cout << "Brand: " << snack[2].brand << endl
         << "Weight: " << snack[2].weight << endl
         << "Calories: " << snack[2].cal << endl << endl;

    delete [] snack;

    return 0;
}

10

#include <iostream>
#include <array>

int main()
{
    using namespace std;

    cout << "Enter your three 40-yard runnings' scores: ";
    array<float, 3> scores;
    cin >> scores[0] >> scores[1] >> scores[2];
    cout << "Average: " << (scores[0] + scores[1] + scores[2]) / 3.0 << endl;

    return 0;
}

c++-pimer-plus-6th-chapter04的更多相关文章

  1. The 6th tip of DB Query Analyzer

      The 6th tip of DB Query Analyzer MA Gen feng (Guangdong Unitoll Services incorporated, Guangzhou ...

  2. [转载]ECMA-262 6th Edition / Draft August 24, 2014 Draft ECMAScript Language Specification

    http://people.mozilla.org/~jorendorff/es6-draft.html#sec-23.4 Draft Report Errors and Issues at: htt ...

  3. Chapter04 运算符(Operator)

    Chapter04 运算符 目录 Chapter04 运算符 4.1 算数运算符 4.2 关系运算符 4.3 逻辑运算符 4.4 赋值运算符 4.5 三元运算符 4.6 运算符的优先级 4.7 标识符 ...

  4. ​Si2151/41 6th Generation Silicon TV Tuner ICs

    ​ The Si2151/41 are the industry's most advanced silicon TV tuner ICs supporting all worldwide terre ...

  5. Codeforces Round #361 Jul.6th B题 ☺译

    最近迈克忙着考前复习,他希望通过出门浮躁来冷静一下.迈克所在的城市包含N个可以浮躁的地方,分别编号为1..N.通常迈克在家也很浮躁,所以说他家属于可以浮躁的地方并且编号为1.迈克从家出发,去一些可以浮 ...

  6. Codeforces Round #361 Jul.6th A题 ☺译

    A.迈克和手机 当迈克在沙滩上游泳的时候,他意外的把他的手机扔进了水里.不过你甭担心因为他立马买了个便宜些的代替品,这个代替品是老款九键键盘,这个键盘只有十个等大的数字按键,按以下方式排列: 1 2 ...

  7. October 6th 2016 Week 41st Thursday

    The outer world you see is a reflection of your inner self. 你拥有什么样的内心,你就会看到什么样的世界. And we eventually ...

  8. September 6th 2016 Week 37th Tuesday

    I only wish to face the sea, with spring flowers blossoming. 我只愿面朝大海,春暖花开. That scenery is beautiful ...

  9. July 6th, Week 28th Wednesday, 2016

    Diligence is the mother of good fortune. 勤勉是好运之母. The mother of good fortune can be diligence, conti ...

  10. August 6th, 2016, Week 32nd, Saturday

    It is not the mountain we conquer, but ourselvess. 我们征服的不是高山,而是我们自己. Difficulties and obstacles, jus ...

随机推荐

  1. python操作串口

    import serial test = serial.Serial("COM1",115200)#这里就已经打开了串口 print(test.portstr) test.writ ...

  2. Ground Defense【不知道叫啥可能就是枚举】

    问题 G: Ground Defense 时间限制: 1 Sec  内存限制: 128 MB 提交: 116  解决: 22 [提交] [状态] [命题人:admin] 题目描述 You are a ...

  3. Centos7.5安装VirtualBox-5.2

    1.查看自己的内核版本 [root@localhost /]# rpm -qa |grep kernel kernel-tools-libs-3.10.0-862.6.3.el7.x86_64 ker ...

  4. SQL优化参考

    1.对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...

  5. Java 多线程案例

    同步代码块 SynchronizedTest类,用来表示取票功能 package concurency.chapter6; public class SynchronizedTest implemen ...

  6. hihoCoder week23 最短路径·一

    spfa 最短路 #include <bits/stdc++.h> using namespace std; #define pb push_back #define INF 1e16; ...

  7. Entity Framework Core

    Entity Framework是一种支持 .NET 开发人员使用 .NET 对象处理数据库的对象关系映射程序 (O/RM). 它不要求提供开发人员通常需要编写的大部分数据访问代码. Entity F ...

  8. 运行python脚本后台执行

    最近搞到了一台服务器,挂一个脚本刷刷河畔在线时间.脚本随便写了两下,能跑到什么时候就随缘了 https://blog.csdn.net/philosophyatmath/article/details ...

  9. HDU 4403 A very hard Aoshu problem(dfs爆搜)

    http://acm.hdu.edu.cn/showproblem.php?pid=4403 题意: 给出一串数字,在里面添加一个等号和多个+号,使得等式成立,问有多少种不同的式子. 思路: 数据量比 ...

  10. SpringLog4j日志体系实现方式

    1.通过web.xml读取log4j配置文件内容 2.通过不同的配置信息,来实现不同的业务输出,注意:log4j可以写入tomcat容器,也可以写入缓存,通过第三方平台读取 #输入规则#log4j.r ...