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 ...
随机推荐
- topcoder srm 410 div1
problem1 link 不包含$gridConnections$ 的联通块一定是连在所有包含$gridConnections$的联通块中最大的那一块上. import java.util.*; i ...
- 《编写高质量代码:Web 前端开发修炼之道》 笔记与读后感
编写高质量代码:Web 前端开发修炼之道/曹刘阳著. —北京:机械工业出版社,2010.5 第一版 涉及到的知识点: 1. CSS Sprites 在国内很多人叫css精灵,是一种网页图片应用处理方式 ...
- 修改userdata的分区大小【转】
本文转载自:https://blog.csdn.net/mike8825/article/details/49833833 版权声明:本文为博主原创文章,未经博主允许不得转载. https:// ...
- SCU 4445 Right turn(dfs)题解
思路:离散化之后,直接模拟就行,标记vis开三维 代码: #include<iostream> #include<algorithm> #include<cstdio&g ...
- MySQL删除数据库时无响应解决办法
删除远程主机上MySQL中的一个数据库时,远程主机一直在响应,无法正常删除. 这个问题的解决办法如下:在远程主机上登录MySQL,执行show full processlist;观察state和inf ...
- hash进阶:使用字符串hash乱搞的姿势
前言 此文主要介绍hash的各种乱搞方法,hash入门请参照我之前这篇文章 不好意思hash真的可以为所欲为 在开头先放一下题表(其实就是我题解中的hash题目qwq) 查询子串hash值 必备的入门 ...
- MySQL 安装步骤
今天用了一下MySQL,刚好看到之前电保存脑的笔记,于是整理了一下,还是记在博客上方便查询. 1.官网下载https://dev.mysql.com/downloads/mysql/之前安装的是mys ...
- P2633 Count on a tree
思路 运用树上差分的思想,转化成一个普通的主席树模型即可求解 代码 #include <cstdio> #include <algorithm> #include <cs ...
- (转载)Windows下小狼毫输入法(Rime)的安装与配置(含导入搜狗词库)
div id="cnblogs_post_body" class="blogpost-body"> 最近彻底烦透了搜狗拼音输入法的各种流氓行为,自动升级不 ...
- 【转载】常用 Java 静态代码分析工具的分析与比较
摘自:http://www.oschina.net/question/129540_23043常用 Java 静态代码分析工具的分析与比较 简介: 本文首先介绍了静态代码分析的基本概念及主要技术,随后 ...