c++-pimer-plus-6th-chapter04
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的更多相关文章
- 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 ...
- Chapter04 运算符(Operator)
Chapter04 运算符 目录 Chapter04 运算符 4.1 算数运算符 4.2 关系运算符 4.3 逻辑运算符 4.4 赋值运算符 4.5 三元运算符 4.6 运算符的优先级 4.7 标识符 ...
- 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 ...
- August 6th, 2016, Week 32nd, Saturday
It is not the mountain we conquer, but ourselvess. 我们征服的不是高山,而是我们自己. Difficulties and obstacles, jus ...
随机推荐
- C++的STL之map自动排序特性
#include <iostream> #include <map> using namespace std; int main() {方法一: map<int,int& ...
- C# 监控代码执行效率
System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch(); stopwatch.Start(); stop ...
- C# 文件与二进制之间的转换
/// <summary> /// 工具类:文件与二进制流间的转换 /// </summary> public class FileBinaryConvertHelper { ...
- Ground Defense【不知道叫啥可能就是枚举】
问题 G: Ground Defense 时间限制: 1 Sec 内存限制: 128 MB 提交: 116 解决: 22 [提交] [状态] [命题人:admin] 题目描述 You are a ...
- shell中的变量a=100, 什么时候作整数使用, 什么时候作字符串使用呢?
shell中的变量a=100, 什么时候作整数使用, 什么时候作字符串使用呢? 这确实是一个困扰很久的一个问题? how it can be an issue? 事实上, 在shell中, 你可以认为 ...
- 抠图|计蒜客2019蓝桥杯省赛 B 组模拟赛(一)
样例输入: 3 4 5 1 0 0 0 1 1 0 1 0 1 1 0 1 0 1 1 0 0 0 1 5 6 1 1 1 1 1 1 1 0 1 0 1 1 1 0 1 0 1 1 1 0 0 0 ...
- 【做题】codechefCOUNTARI——分块FFT
记本题数组长度为\(n\),权值大小为\(m\). 首先,暴力显然是\(O(n^2)\)的. 先瞄一眼tag,然后发现这是FFT. 显然,问题的关键在于要满足i,j,k之间的位置关系.于是考虑分治FF ...
- GC 垃圾收集
算法: 没有使用引用计数算法.使用的是GC Roots 可达性算法. 复制算法:新生代,老年代. 标记-整理算法:一般会对对象标记几次才会清理掉.然后从新整理物理内存空间. 分代收集算法:更加对象存活 ...
- 关不掉.vbs
创建: 1.在桌面新建一个 关不掉.txt 文本文档 2.打开输入一下内容 do msgbox"信不信你关不掉我" msgbox"哈哈,你相信了吧" msgbo ...
- SAP成本核算说明
SAP成本核算说明 <SAP财务管控——财务总监背后的管理大师>京东有售. > SAP成本核算说明 说明: 1. 原材料采用移动平均价核算:产成品采用计划(标准)成本核算: 2 ...