Chapter Review

  1. Having more than one integer type lets you choose the type that is best suited to a particular need. For example, you could use short to conserve space or long to guarantee storage capacity or to find that a particular type speed up a particular calculation.
  2. short ribs = 80; // or short int ribs = 80;
    unsigned int q = 42110; // or unsigned q = 42110;
    unsigned long ants = 3000000000; // or long long ants = 3000000000;
    Note: Don't count on int being large enough to hold 3,000,000,000. Also if your system supports universal list-initialization, you could use it:
    short rbis = {80};
    unsigned int q {42110};
    long long ants {3000000000};
  3. C++ provides no automatic safeguards to keep you from exceeding integer limits; you can use the climits header file to determine what the limits are.
  4. The constant 33L is type long, whereas the constant 33 is type int.
  5. The two statements are not really equivalent, although they have the same effect on some system. Most importantly, the first statement assigns the letter A to grade only on a system using the ASCII code, while the second statement also works for other codes. Second, 65 is a type int constant, whereas A is a type char constant.
  6. Here are four ways:
    char c = 88;
    cout << c << endl; // char type prints as character
    cout.put(char(88)); // put() prints char as character
    cout << char(88) << endl; // new-style type cast value to char
    cout << (char) 88 << endl; // old-style type cast value to char
  7. The answer depends on how large the two types are. If long is 4 bytes, there is no loss. Thats because the largest long value would be about 2 billion, which is 10 digits. Because double provides at least 13 significant figures, no rounding would be needed. The long long type, on the other hand, can reach 19 digits, which exceeds the 13 significant figures guaranteed for double.
  8. a. 8 * 9 + 2 is 72 + 2 is 74
    b. 6 * 3 / 4 is 18 / 4 is 4
    c. 3 / 4 * 6 is 0 * 6 is 0
    d. 6.0 * 3 / 4 is 18.0 / 4 is 4.5
    e. 15 % 4 is 3
  9. Either of the following would work for the first task:
    int pos = (int) x1 + (int) x2;
    int pos = int (x1) + int (x2);
    To add them as type double and then convert, you could do either of the following:
    int pos = (int) (x1 + x2);
    int pos = int (x1 + x2);
  10. a. int
    b. float
    c. char
    d. char32_t
    e. double

Programming Exercises

1

#include <iostream>
const int Factor{12};

int main()
{
    using namespace std;

    cout << "Input your height(inches): ";
    int height, feet, inches;
    cin >> height;
    feet = height / Factor;
    inches = height % Factor;
    cout << "Your height is equal to " << feet << " feet," << inches << " inches" << endl;

    return 0;
}

2

#include <iostream>

int main()
{
    using namespace std;

    const double Inches_per_foot = 12;
    const double Inches_per_meter{0.0254};
    const double Kilo_per_pound{2.2};

    cout << "Enter your height in feet and inches(example: 14 17): ";
    double feet;
    double inches;
    cin >> feet;
    cin >> inches;
    cout << "Enter your weight in pounds: ";
    double weight;
    cin >> weight;
    double i = (feet * Inches_per_foot + inches) * Inches_per_meter;
    cout << "Your BMI is: " << weight * Kilo_per_pound / (i * i) << endl;

    return 0;
}

3

#include <iostream>

int main()
{
    using namespace std;

    const double Mid{60.0};

    cout << "Enter a latitude in degrees, minutes, and seconds:" << endl;
    cout << "First, enter the degrees: ";
    int degrees;
    cin >> degrees;
    cout << "Next, enter the minutes of arc: ";
    int minutes;
    cin >> minutes;
    cout << "Finally, enter the seconds of arc: ";
    int seconds;
    cin >> seconds;
    cout << degrees << " degrees, " << minutes << " minutes, " << seconds << " seconds = "
         << double (degrees) + minutes / Mid + seconds / (Mid * Mid) << endl;

    return 0;
}

4

#include <iostream>

int main()
{
    using namespace std;

    const int H_per_day{24};
    const int M_per_hour = {60};
    const int S_per_seconds = 60;

    cout << "Enter the number of seconds: ";
    long long seconds;
    cin >> seconds;
    long long d = seconds / (H_per_day * M_per_hour * S_per_seconds);
    long long h = seconds % (H_per_day * M_per_hour * S_per_seconds) / (M_per_hour * S_per_seconds);
    long long m = seconds % (H_per_day * M_per_hour * S_per_seconds) % (M_per_hour * S_per_seconds) / S_per_seconds;
    long long s = seconds % (H_per_day * M_per_hour * S_per_seconds) % (M_per_hour * S_per_seconds) % S_per_seconds;
    cout << seconds << " seconds = "
         << d << " days, "
         << h << " hours, "
         << m << " minutes, "
         << s << " seconds \n";

    return 0;
}

5

#include <iostream>

int main()
{
    using namespace std;

    cout << "Enter the world's population: ";
    long long p_of_world;
    cin >> p_of_world;
    cout << "Enter the population of the China: ";
    long long p_of_nation;
    cin >> p_of_nation;
    cout << "The population of the China is " << double (p_of_nation) / double (p_of_world) * 100.0
         << "% of the world population. \n";

    return 0;
}

6

#include <iostream>

int main()
{
    using namespace std;

    cout << "Enter you have driven in miles: ";
    int mile;
    cin >> mile;
    cout << "Enter you have costed of gasoline: ";
    int gas;
    cin >> gas;
    cout << double (mile) / double (gas) << " miles per gallon your car has gotten. \n";

    return 0;
}

7

#include <iostream>

int main()
{
    using namespace std;

    const double Miles_per_kilo{6.214e-1};
    const double Liters_per_gallon = 3.875;

    cout << "Enter European style (liters per 100 kilometers): ";
    double eu;
    cin >> eu;
    int temp = int ((1.0 / eu) * (Miles_per_kilo * 100.0) * Liters_per_gallon);
    cout << eu << " l/100 km = " << temp << " mpg \n";
    return 0;
}

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

  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. chapter03

    import scala.collection.mutable.ArrayBuffer /** * Created by EX-CHENZECHAO001 on 2018-03-29. */class ...

  4. Chapter03 Java变量

    Chapter03 变量 目录 Chapter03 变量 3.1 为什么需要变量 3.1.1 一个程序就是一个世界 3.1.2 变量是程序的基本组成单位 3.1.3 简单原理图 3.2 变(变化)量( ...

  5. ​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 ...

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

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

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

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

  8. October 6th 2016 Week 41st Thursday

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

  9. September 6th 2016 Week 37th Tuesday

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

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

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

随机推荐

  1. 针对Xcode 9 + iOS11 的修改,及iPhone X的适配

    1,UIScrollView的automaticallyAdjustsScrollViewInsets 失效了. automaticallyAdjustsScrollViewInsets,当设置为YE ...

  2. Eclipse自动生成方法注释 快捷键

    自动生成方法的注释格式,例如 /*** @param str* @return* @throws ParseException*/ 快捷键是 ALT + SHIFT + J,将光标放在方法名上,按快捷 ...

  3. 利用sqlmap对网站进行sql注入检测

    1.下载sqlmap github地址:https://github.com/sqlmapproject/sqlmap/zipball/master 2.sqlmap的运行环境需要python,这个网 ...

  4. 如何在servlet中获取spring创建的bean

    package com.yxf.controller; import java.io.IOException; import javax.servlet.ServletException; impor ...

  5. Junit中的setUp()与setUpBefore(), tearDown()与tearDownAfterClass()解析

    @BeforeClass public static void setUpBeforeClass() throws Exception { } @AfterClass public static vo ...

  6. Visual Studio Code 的 launch.json 解析

    { "version": "0.2.0", "configurations": [ { "name": "(g ...

  7. C语言 字符串大小写转换 自定义函数

    #include <stdio.h>#include <stdlib.h>#include <string.h> char * strtolower(char * ...

  8. String comparison is too slow in R language

    ## String comparison is too slow in R language ## it will take 3 minutes, it is too slow date() strA ...

  9. P2604 [ZJOI2010]网络扩容

    思路 简单的费用流问题,跑出第一问后在残量网络上加边求最小费用即可 代码 #include <cstdio> #include <algorithm> #include < ...

  10. 题解——loj6279 数列分块入门3 (分块)

    用set维护有序序列 或许sort也可以,但这题的前驱定义是严格小于 所以要去重 然后就是记得自己打的加法tag在query的时候一定要算上 话说这题数据有点fake啊忘了查询算上自己的标记了还有70 ...