c++-pimer-plus-6th-chapter03
Chapter Review
- 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 orlong
to guarantee storage capacity or to find that a particular type speed up a particular calculation.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 onint
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};
- 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.- The constant 33L is type
long
, whereas the constant 33 is typeint
.- 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 typeint
constant, whereasA
is a typechar
constant.- 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
- The answer depends on how large the two types are. If
long
is 4 bytes, there is no loss. Thats because the largestlong
value would be about 2 billion, which is 10 digits. Becausedouble
provides at least 13 significant figures, no rounding would be needed. Thelong long
type, on the other hand, can reach 19 digits, which exceeds the 13 significant figures guaranteed fordouble
.- 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- 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 typedouble
and then convert, you could do either of the following:
int pos = (int) (x1 + x2);
int pos = int (x1 + x2);
- 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的更多相关文章
- The 6th tip of DB Query Analyzer
The 6th tip of DB Query Analyzer MA Gen feng (Guangdong Unitoll Services incorporated, Guangzhou ...
- [转载]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 ...
- chapter03
import scala.collection.mutable.ArrayBuffer /** * Created by EX-CHENZECHAO001 on 2018-03-29. */class ...
- Chapter03 Java变量
Chapter03 变量 目录 Chapter03 变量 3.1 为什么需要变量 3.1.1 一个程序就是一个世界 3.1.2 变量是程序的基本组成单位 3.1.3 简单原理图 3.2 变(变化)量( ...
- 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 ...
- Codeforces Round #361 Jul.6th B题 ☺译
最近迈克忙着考前复习,他希望通过出门浮躁来冷静一下.迈克所在的城市包含N个可以浮躁的地方,分别编号为1..N.通常迈克在家也很浮躁,所以说他家属于可以浮躁的地方并且编号为1.迈克从家出发,去一些可以浮 ...
- Codeforces Round #361 Jul.6th A题 ☺译
A.迈克和手机 当迈克在沙滩上游泳的时候,他意外的把他的手机扔进了水里.不过你甭担心因为他立马买了个便宜些的代替品,这个代替品是老款九键键盘,这个键盘只有十个等大的数字按键,按以下方式排列: 1 2 ...
- October 6th 2016 Week 41st Thursday
The outer world you see is a reflection of your inner self. 你拥有什么样的内心,你就会看到什么样的世界. And we eventually ...
- September 6th 2016 Week 37th Tuesday
I only wish to face the sea, with spring flowers blossoming. 我只愿面朝大海,春暖花开. That scenery is beautiful ...
- July 6th, Week 28th Wednesday, 2016
Diligence is the mother of good fortune. 勤勉是好运之母. The mother of good fortune can be diligence, conti ...
随机推荐
- 使用Navicat for MySQL添加外键约束
转载:http://blog.csdn.net/u013215018/article/details/54981216 现在有两个表一张是Roles表(角色表),一张是RoleUser表(用户角色) ...
- Bootstrap3基础 navbar 导航条 简单示例
内容 参数 OS Windows 10 x64 browser Firefox 65.0.2 framework Bootstrap 3.3.7 editor ...
- Ubuntu 系统学习
apt 命令 apt-get remove [app] # 删除已安装的软件包(保留配置文件),不会删除依赖软件包,且保留配置文件 apt-get remove --pure [app] # 删除已安 ...
- Codeforces Round #535 (Div. 3) 解题报告
CF1108A. Two distinct points 做法:模拟 如果两者左端点重合就第二条的左端点++就好,然后输出左端点 #include <bits/stdc++.h> usin ...
- PL/SQL Developer几个使用小技巧
1.选中sql语句的当前行 鼠标连续点击所在行3次. 2.记住登陆密码 工具 -> 首选项 -> Oracle -> 登录历史,勾选“带口令存储”. 3.查看Oracle的tnsna ...
- P3211 [HNOI2011]XOR和路径
思路 看到异或,容易联想到二进制位之间是相互独立的,所以可以把问题变成每个二进制位为1的概率再乘上(1<<pos)的值 假设现在考虑到pos位,设f[i]为第i个节点期望的异或和第pos位 ...
- Kylin介绍2
原理 官网 doc cube介绍 安装 案例 企业级特性 Apache Kylin 1.5的新功能和架构改变 Java API 通过java代码对kylin进行cube build kylin从入门 ...
- EFI环境下的Ubuntu&Win10双系统安装
因为是win10是EFI启动的,所以网上的easyBCD方法就不可以用了,这里用到的不是ultraiso软碟通,用的哪个忘了 不过只要能写入U盘做成启动盘就ok 具体参考的是https://blog. ...
- HDU 3526 Computer Assembling(最小割)
http://acm.hdu.edu.cn/showproblem.php?pid=3526 题意:有个屌丝要配置电脑,现在有n个配件需要购买,有两家公司出售这n个配件,还有m个条件是如果配件x和配件 ...
- webpack插件配置(二)- HtmlWebpackPlugin
作用 简化Html文件的创建,以便为你的webpack bundle包提供服务.这对于在文件名中包含每次会随着编译而发生变化的hash的webpack bundle尤其有用.插件可以生成一个HTML文 ...