C Primer Plus第6版中文版勘误表
- 格式:doc
- 大小:40.00 KB
- 文档页数:5
1、//count.cpp#include <iostream>using namespace std;int main(){char ch;int count = 0;cout << "Enter a string($ to quit):\n";while (cin.get(ch)){if (ch != '$'){count++;cout << ch;}else{cin.putback(ch);break;}}cout << "Count is " << count << endl;system("pause");return 0;}2、//filein.cpp#include <iostream>#include <fstream>#include <cstdlib>int main(int argc, char *argv[]){using namespace std;if (argc == 1){cerr << "Usage: " << argv[0] << " filename[s]\n";exit(EXIT_FAILURE);}ofstream fout(argv[1], ios::out|ios::app);{cerr << "Can't open " << argv[1] << " file for output.\n";exit(EXIT_FAILURE);}char ch;cout << "Enter a string: \n";while (cin.get(ch)){if (ch != '\n')fout << ch;elsebreak;}fout << endl;fout.close();system("pause");return 0;}3、//copy.cpp#include <iostream>#include <fstream>#include <cstdlib>int main(int argc, char *argv[]){using namespace std;if (argc == 1){cerr << "Usage: " << argv[0] << " filename[s]\n";exit(EXIT_FAILURE);}ifstream fin;char ch;fin.open(argv[1], ios::in);if (!fin.is_open()){cerr << "Could not open " << argv[1] << endl;exit(EXIT_FAILURE);}ofstream fout(argv[2], ios::out | ios::trunc);{cerr << "Could not open " << argv[1] << endl;exit(EXIT_FAILURE);}cout << "Here are the current contents of th "<< argv[1] << " file:\n";while (fin.get(ch)){cout << ch;fout << ch;}fin.close();fout.close();system("pause");return 0;}//a.txtAbcdefghijklmnopqrstuvwxyz4、//copy_cat.cpp#include <iostream>#include <fstream>#include <cstdlib>#include <string>using namespace std;const char *file1 = "a.txt";const char *file2 = "b.txt";const char *file3 = "c.txt";int main(){ifstream fin1, fin2;fin1.open(file1);fin2.open(file2);ofstream fout;fout.open(file3, ios_base::out | ios_base::trunc);string s1, s2;if (!fin1.is_open() || !fin2.is_open()){cerr << "Can't open " << file1 << " or " << file2 << endl;exit(EXIT_FAILURE);}if (!fout.is_open()){cerr << "Can't open " << file3 << endl;exit(EXIT_FAILURE);}while (!fin1.eof() && !fin2.eof()){getline(fin1, s1);cout << "File1 " << s1 << endl;getline(fin2, s2);cout << "File2 " << s2 << endl;fout << s1 << " " << s2 << endl;}while (!fin1.eof()){getline(fin1, s1);cout << "More file1 " << s1 << endl;fout << s1 << endl;}while (!fin2.eof()){getline(fin2, s2);cout << "More file2 " << s2 << endl;fout << s2 << endl;}fin1.close();fin2.close();fout.close();system("pause");return 0;}//a.txteggs kites donutsballoons hammersstones//b.txtzero lassitudefinance drama5、//name.cpp#include <iostream>#include <string>#include <set>#include <algorithm>#include <iterator>#include <fstream>const char *file1 = "mat.dat";const char *file2 = "pat.dat";const char *file3 = "matnpat.dat";int main(){using namespace std;string fname1;set<string> A;ifstream finA, finB;finA.open(file1);finB.open(file2);ofstream fout;ostream_iterator<string, char> out1(cout, " "), out2(fout, "\n");fout.open(file3, ios_base::out | ios_base::trunc);if (!finA.is_open() || !finB.is_open()){cerr << "Can't open " << file1 << " or " << file2 << endl;exit(EXIT_FAILURE);}if (!fout.is_open()){cerr << "Can't open " << file3 << endl;exit(EXIT_FAILURE);}while (!finA.eof()){getline(finA, fname1);A.insert(fname1);}cout << "Mat's friends: \n";copy(A.begin(), A.end(), out1);cout << endl;string fname2;set<string> B;while (!finB.eof()){getline(finB, fname2);B.insert(fname2);}cout << "Pat's friends: \n";copy(B.begin(), B.end(), out1);cout << endl;cout << "Union of Mat and Pat's friends: ";set_union(A.begin(), A.end(), B.begin(), B.end(), out1);set_union(A.begin(), A.end(), B.begin(), B.end(), out2);cout << endl;finA.close();finB.close();fout.close();system("pause");return 0;}6、//emp.h#ifndef EMP_H_#define EMP_H_#include <iostream>#include <string>#include <fstream>using namespace std;enum classtype{ Employee, Manager, Fink, Highfink };class abstr_emp{private:string fname;string lname;string job;public:abstr_emp();abstr_emp(const string &fn, const string &ln,const string &j);virtual void ShowAll()const;virtual void SetAll();friend ostream &operator<<(ostream &os, const abstr_emp &e);virtual ~abstr_emp() = 0;virtual void writeall(ofstream &ofs);virtual void getall(ifstream &ifs);};class employee :public abstr_emp{public:employee();employee(const string &fn, const string &ln, const string &j);virtual void ShowAll()const;virtual void SetAll();virtual void writeall(ofstream &ofs);virtual void getall(ifstream &ifs);};class manager :virtual public abstr_emp{private:int inchargeof;protected:int InChargeOf()const { return inchargeof; }int &InChargeOf(){ return inchargeof; } public:manager();manager(const string &fn, const string &ln, const string &j, int ico = 0);manager(const abstr_emp &e, int ico = 0);manager(const manager &m);virtual void ShowAll()const;virtual void SetAll();virtual void writeall(ofstream &ofs);virtual void getall(ifstream &ifs);void getInCharge(){cout << "Enter inchargeof: ";cin >> inchargeof;}void writeInCharge(ofstream &ofs){ofs << inchargeof << endl;}void readInCharge(ifstream &ifs){ifs >> inchargeof;}};class fink :virtual public abstr_emp{private:string reportsto;protected:const string ReportsTo()const{ return reportsto; }string &ReportsTo(){ return reportsto; }public:fink();fink(const string &fn, const string &ln,const string &j, const string &rpo);fink(const abstr_emp &e, const string &rpo);fink(const fink &e);virtual void ShowAll()const;virtual void SetAll();virtual void writeall(ofstream &ofs);virtual void getall(ifstream &ifs);void getReportsTo(){cout << "Enter reportsto: ";cin >> reportsto;}void writeReportsTo(ofstream &ofs){ofs << reportsto << endl;}void readReportsTo(ifstream &ifs){ifs >> reportsto;}};class highfink :public manager, public fink{public:highfink();highfink(const string &fn, const string &ln,const string &j, const string &rpo, int ico = 0);highfink(const abstr_emp &e, const string &rpo, int ico = 0);highfink(const fink &f, int ico = 0);highfink(const manager &m, const string &rpo);highfink(const highfink &h);virtual void ShowAll()const;virtual void SetAll();virtual void writeall(ofstream &ofs);virtual void getall(ifstream &ifs);};#endif//emp.cpp#include "emp.h"abstr_emp::abstr_emp() :fname("no one"), lname("no one"), job("no job") {}abstr_emp::abstr_emp(const string &fn, const string &ln,const string &j) : fname(fn), lname(ln), job(j){}void abstr_emp::ShowAll()const{cout << "Firstname: " << fname << endl;cout << "Lastname: " << lname << endl;cout << "Job is: " << job << endl;}void abstr_emp::SetAll(){cout << "Enter firstname: ";getline(cin, fname);cout << "Enter lastname: ";getline(cin, lname);cout << "Enter position: ";getline(cin, job);}ostream &operator<<(ostream &os, const abstr_emp &e){os << e.fname << " " << e.lname << ", " << e.job << endl;return os;}abstr_emp::~abstr_emp(){}void abstr_emp::writeall(ofstream &ofs){ofs << fname << "\n" << lname << "\n" << job << "\n"; }void abstr_emp::getall(ifstream &ifs){getline(ifs, fname);getline(ifs, lname);getline(ifs, job);}employee::employee() :abstr_emp(){}employee::employee(const string &fn, const string &ln, const string &j) : abstr_emp(fn, ln, j){}void employee::ShowAll()const{abstr_emp::ShowAll();}void employee::SetAll(){abstr_emp::SetAll();}void employee::writeall(ofstream &ofs){ofs << Employee << endl;abstr_emp::writeall(ofs);}void employee::getall(ifstream &ifs){abstr_emp::getall(ifs);}manager::manager() :abstr_emp(){}manager::manager(const string &fn, const string &ln,const string &j, int ico) : abstr_emp(fn, ln, j), inchargeof(ico){}manager::manager(const abstr_emp &e, int ico) : abstr_emp(e), inchargeof(ico) {}manager::manager(const manager &m) : abstr_emp(m){}void manager::ShowAll()const{abstr_emp::ShowAll();cout << "Inchargeof: " << InChargeOf() << endl;}void manager::SetAll(){abstr_emp::SetAll();cout << "Enter inchargeof: ";(cin >> inchargeof).get();}void manager::writeall(ofstream &ofs){ofs << Manager << endl;abstr_emp::writeall(ofs);ofs << inchargeof << endl;}void manager::getall(ifstream &ifs){abstr_emp::getall(ifs);ifs >> inchargeof;}fink::fink() :abstr_emp(){}fink::fink(const string &fn, const string &ln,const string &j, const string &rpo) : abstr_emp(fn, ln, j), reportsto(rpo){}fink::fink(const abstr_emp &e, const string &rpo) : abstr_emp(e), reportsto(rpo){}fink::fink(const fink &e) : abstr_emp(e){}void fink::ShowAll()const{abstr_emp::ShowAll();cout << "Reportsto: " << ReportsTo() << endl;}void fink::SetAll(){abstr_emp::SetAll();cout << "Enter reportsto: ";cin >> reportsto;}void fink::writeall(ofstream &ofs){ofs << Fink << endl;abstr_emp::writeall(ofs);ofs << reportsto << endl;}void fink::getall(ifstream &ifs){abstr_emp::getall(ifs);ifs >> reportsto;}highfink::highfink() :abstr_emp(), manager(), fink(){}highfink::highfink(const string &fn, const string &ln,const string &j, const string &rpo, int ico) : abstr_emp(fn, ln, j), manager(fn, ln, j, ico), fink(fn, ln, j, rpo){}highfink::highfink(const abstr_emp &e, const string &rpo, int ico) : abstr_emp(e), manager(e, ico), fink(e, rpo){}highfink::highfink(const fink &f, int ico) : abstr_emp(f), manager(f, ico), fink(f){}highfink::highfink(const manager &m, const string &rpo) : abstr_emp(m), manager(m), fink(m, rpo){}highfink::highfink(const highfink &h) : abstr_emp(h), manager(h), fink(h){}void highfink::ShowAll()const{abstr_emp::ShowAll();cout << "InChargeOf: ";cout << manager::InChargeOf() << endl;cout << "ReportsTo: ";cout << fink::ReportsTo() << endl;}void highfink::SetAll(){abstr_emp::SetAll();manager::getInCharge();fink::getReportsTo();}void highfink::writeall(ofstream &ofs){ofs << Highfink << endl;abstr_emp::writeall(ofs);manager::writeInCharge(ofs);fink::writeReportsTo(ofs);}void highfink::getall(ifstream &ifs){abstr_emp::getall(ifs);manager::readInCharge(ifs);fink::readReportsTo(ifs);}//useemp.cpp#include "emp.h"const int MAX = 10;const char *file = "a.txt";int main(void){abstr_emp *pc[MAX];char ch;ifstream fin;fin.open(file);int i = 0;if (fin.is_open()){cout << "Here are the current contents of the "<< file << " file:\n";int classtype;i = 0;while ((fin >> classtype).get(ch)){switch (classtype){case Employee:pc[i] = new employee;break;case Manager:pc[i] = new manager;break;case Fink:pc[i] = new fink;break;case Highfink:pc[i] = new highfink;break;}cout << classtype << endl;pc[i]->getall(fin);pc[i++]->ShowAll();}}fin.close();ofstream fout;fout.open(file, ios_base::out | ios_base::app);if (!fout.is_open()){cerr << "Can't open " << file << " file for output.\n";exit(EXIT_FAILURE);}cout << "e to employee, m to manager\n"<< "f to fink, h to highfink\n"<< "q to quit: ";int index = 0;while (cin.get(ch).get() && ch != 'q'&&index < MAX){switch (ch){case'e':pc[index] = new employee;pc[index]->SetAll();index++;break;case'm':pc[index] = new manager;pc[index]->SetAll();index++;break;case'f':pc[index] = new fink;pc[index]->SetAll();index++;break;case'h':pc[index] = new highfink;pc[index]->SetAll();index++;break;default:cout << "Try again";break;}if (index > MAX)break;cout << "e to employee, m to manager\n"<< "f to fink, h to highfink\n"<< "q to quit: ";}for (i = 0; i < index; i++)pc[i]->writeall(fout);fout.close();fin.clear();fin.open(file);if (fin.is_open()){cout << "Here are the current contents of the "<< file << " file:\n";int classtype;i = 0;while ((fin >> classtype).get(ch)){switch (classtype){case Employee:pc[i] = new employee;break;case Manager:pc[i] = new manager;break;case Fink:pc[i] = new fink;break;case Highfink:pc[i] = new highfink;break;}cout << classtype << endl;pc[i]->getall(fin);pc[i++]->ShowAll();}}cout << "Done.\n";system("pause");return 0;}7、//vcopy.cpp#include <iostream>#include <vector>#include <string>#include <iterator>#include <algorithm>#include <fstream>#include <cstdlib>using namespace std;void ShowStr(const string &);void GetStrs(ifstream &, vector<string> &);class Store{ofstream &fout;public:Store(ofstream &os) :fout(os){}void operator()(const string &str);};void Store::operator()(const string &str){size_t len = str.size();fout.write((char *)&len, sizeof(size_t));fout.write(str.data(), len);}int main(){vector<string> vostr;string temp;cout << "Enter strings (empty line to quit):\n";while (getline(cin, temp) && temp[0] != '\0')vostr.push_back(temp);cout << "Here is your input.\n";for_each(vostr.begin(), vostr.end(), ShowStr);ofstream fout("strings.dat", ios_base::out | ios_base::binary);for_each(vostr.begin(), vostr.end(), Store(fout));fout.close();vector<string> vistr;ifstream fin("strings.dat", ios_base::in | ios_base::binary);if (!fin.is_open()){cerr << "Could not open file for input.\n";exit(EXIT_FAILURE);}GetStrs(fin, vistr);cout << "\nHere are the strings read from the file:\n";for_each(vistr.begin(), vistr.end(), ShowStr);system("pause");return 0;}void ShowStr(const string &str){cout << str << endl;}void GetStrs(ifstream &fin, vector<string> &str){char *s;size_t len;while (fin.read((char *)&len, sizeof(size_t))){s = new char[len];fin.read(s, len);s[len + 1] = '\0';str.push_back(s);}}。
1、//tv.h#ifndef TV_H_#define TV_H_#include <iostream>using namespace std;classTv{friend class Remote;public:enum { Off, On };enum { MinVal, MaxVal = 20 };enum { Antenna, Cable };enum { TV, DVD };enum { USUAL, EXCHANGE };Tv(int s = Off, int mc = 125) :state(s), volume(5),maxchannel(mc), channel(2), mode(Cable), input(TV){} ~Tv(){}voidonoff(){ state = (state == On) ? Off : On; }boolison()const{ return state == On; }boolvolup();boolvoldown();voidchanup();voidchandown();voidset_mode(){ mode = (mode == Antenna) ? Cable : Antenna; } voidset_input(){ input = (input == TV) ? DVD : TV; }void settings()const;voidset_rmode(Remote &r);private:int state;int volume;intmaxchannel;int channel;int mode;int input;};class Remote{private:friend class Tv;enum { USUAL, EXCHANGE };int mode;intfmode;public:Remote(int m = Tv::TV, int f = USUAL) :mode(m), fmode(f){}boolvolup(Tv&t){ return t.volup(); }boolvoldown(Tv&t){ return t.voldown(); }voidonoff(Tv&t){ t.onoff(); }voidchanup(Tv&t){ t.chanup(); }voidchandown(Tv&t){ t.chandown(); }voidset_chan(Tv&t, int c){ t.channel = c; }voidset_mode(Tv&t){ t.set_mode(); }voidset_input(Tv&t){ t.set_input(); }voidmode_show()const{ cout<< "Remote pretent mode is " <<fmode<<endl; } };inline void Tv::set_rmode(Remote &r){if (ison()){r.fmode = Remote::EXCHANGE;r.mode_show();}}#endif//tvfm.h#ifndef TVFM_H_#define TVFM_H_#include <iostream>using namespace std;classTv;class Remote{public:enum State{ Off, On };enum { MinVal, MaxVal = 20 };enum { Antenna, Cable };enum { TV, DVD };private:int mode;public:Remote(int m = TV) :mode(m){}boolvolup(Tv&t);boolvoldown(Tv&t);voidonoff(Tv&t);voidchanup(Tv&t);voidchandown(Tv&t);voidset_chan(Tv&t, int c);voidset_mode(Tv&t);voidset_input(Tv&t);};classTv{public:friend void Remote::set_chan(Tv&t, int c);enum State{ Off, On };enum { MinVal, MaxVal = 20 };enum { Antenna, Cable };enum { TV, DVD };Tv(int s = Off, int mc = 125) :state(s), volume(5),maxchannel(mc), channel(2), mode(Cable), input(TV){} ~Tv(){}voidonoff(){ state = (state == On) ? Off : On; }boolison()const{ return state == On; }boolvolup();boolvoldown();voidchanup();voidchandown();voidset_mode(){ mode = (mode == Antenna) ? Cable : Antenna; } voidset_input(){ input = (input == TV) ? DVD : TV; }void settings()const;private:int state;int volume;intmaxchannel;int channel;int mode;int input;};inlinebool Remote::volup(Tv&t){ return t.volup(); }inlinebool Remote::voldown(Tv&t){ return t.voldown(); } inline void Remote::onoff(Tv&t){ t.onoff(); }inline void Remote::chanup(Tv&t){ t.chanup(); }inline void Remote::chandown(Tv&t){ t.chandown(); } inline void Remote::set_chan(Tv&t, int c){ t.channel = c; } inline void Remote::set_mode(Tv&t){ t.set_mode(); } inline void Remote::set_input(Tv&t){ t.set_input(); }#endif//tv.cpp#include "tv.h"//#include "tvfm.h"boolTv::volup(){if (volume <MaxVal){volume++;return true;}elsereturn false;}boolTv::voldown(){if (volume>MinVal){volume--;return true;}elsereturn false;}voidTv::chanup(){if (channel <maxchannel)channel++;elsechannel = 1;}voidTv::chandown(){if (channel>1)channel--;elsechannel = maxchannel;}voidTv::settings()const{cout<< "TV is " << (state == Off ? "Off" : "On") <<endl;if (state == On){cout<< "Volume setting = " << volume <<endl;cout<< "Channel setting = " << channel <<endl;cout<< "Mode = " << (mode == Antenna ? "antenna" : "cable") <<endl;cout<< "Input = " << (input == TV ? "TV" : "DVD") <<endl;}}//use_tv.cpp#include "tv.h"int main(){Tv s42;Remote grey;grey.mode_show();cout<< "Initial settings for 42\" TV:\n";s42.settings();s42.onoff();s42.chanup();cout<< "\nAdjusted settings for 42\" TV:\n";s42.settings();s42.set_rmode(grey);grey.set_chan(s42, 10);grey.volup(s42);grey.volup(s42);cout<< "\n42\" settings after using remote:\n";s42.settings();Tvs58(Tv::On);s58.set_mode();grey.set_chan(s58, 28);cout<< "\n58\" settings:\n";s58.settings();s58.set_rmode(grey);system("pause");return 0;}2、//exc_mean.h#ifndef EXC_MEAN_H_#define EXC_MEAN_H_#include <iostream>#include <cmath>#include <stdexcept>#include <string>using namespace std;classbad_hmean :public logic_error{private:string name;public:explicitbad_hmean(const string &n = "hmean", const string &s = "Error in hmean()\n");stringmesg();virtual ~bad_hmean()throw(){}};bad_hmean::bad_hmean(const string &n, const string &s) :name(n), logic_error(s){}inline string bad_hmean::mesg(){return "hmean() arguments a=-b should be div a+b=0!\n";}classbad_gmean :public logic_error{private:string name;public:explicitbad_gmean(const string &n = "gmean", const string &s = "Error in gmean()\n");stringmesg();virtual ~bad_gmean()throw(){}};bad_gmean::bad_gmean(const string &n, const string &s) :name(n), logic_error(s){inline string bad_gmean::mesg(){return "gmean() arguments should be >= 0\n";}#endif//error.cpp#include "exc_mean.h"doublehmean(double a, double b);doublegmean(double a, double b);int main(){double x, y, z;cout<< "Enter two numbers:";while (cin>> x >> y){try{z = hmean(x, y);cout<< "Harmonic mean of " << x << " and " << y<<" is " << z <<endl;cout<< "Geomettric mean of " << x << " and " << y<<" is " <<gmean(x, y) <<endl;cout<< "Enter next set of numbers <q to quit>: ";}catch (bad_hmean&bg){cout<<bg.what();cout<< "Error message: \n" <<bg.mesg() <<endl;cout<< "Try again.\n";continue;}catch (bad_gmean&hg){cout<<hg.what();cout<< "Error message: \n" <<hg.mesg() <<endl;cout<< "Sorry, you don't get to play and more.\n";break;}}cout<< "Bye!\n";system("pause");return 0;}doublehmean(double a, double b){if (a == -b)throwbad_hmean();return 2.0*a*b / (a + b);}doublegmean(double a, double b){if (a < 0 || b < 0)throwbad_gmean();returnsqrt(a*b);}3、//exc_mean.h#ifndef EXC_MEAN_H_#define EXC_MEAN_H_#include <iostream>#include <cmath>#include <stdexcept>#include <string>using namespace std;classbad_hmean :public logic_error{private:string name;public:double v1;double v2;explicitbad_hmean(double a = 0, double b = 0,const string &s = "Error in hmean()\n");voidmesg();virtual ~bad_hmean()throw(){}};bad_hmean::bad_hmean(double a, double b, const string &s) :v1(a), v2(b), logic_error(s){name = "hmean";}inline void bad_hmean::mesg(){cout<< name << "(" << v1 << ", " << v2<< ") arguments a=-b should be div a+b=0!\n";}classbad_gmean :public bad_hmean{private:string name;public:explicitbad_gmean(double a = 0, double b = 0,const string &s = "Error in gmean()\n");voidmesg();virtual ~bad_gmean()throw(){}};bad_gmean::bad_gmean(double a, double b, const string &s):bad_hmean(a, b, s){name = "gmean";}inline void bad_gmean::mesg(){cout<< name << "(" <<bad_hmean::v1 << ", " <<bad_hmean::v2 << ") arguments should be >= 0\n";}#endif//error.cpp#include "exc_mean.h"doublehmean(double a, double b);doublegmean(double a, double b);int main(){double x, y, z;cout<< "Enter two numbers:";while (cin>> x >> y){try{z = hmean(x, y);cout<< "Harmonic mean of " << x << " and " << y<<" is " << z <<endl;cout<< "Geomettric mean of " << x << " and " << y<<" is " <<gmean(x, y) <<endl;cout<< "Enter next set of numbers <q to quit>: ";}catch (bad_gmean&hg){cout<<hg.what();cout<< "Error message: \n";hg.mesg();cout<<endl;cout<< "Sorry, you don't get to play and more.\n";break;}catch (bad_hmean&bg){cout<<bg.what();cout<< "Error message: \n";bg.mesg();cout<<endl;cout<< "Try again.\n";continue;}}cout<< "Bye!\n";system("pause");return 0;}doublehmean(double a, double b){if (a == -b)throwbad_hmean();return 2.0*a*b / (a + b);}doublegmean(double a, double b){if (a < 0 || b < 0)throwbad_gmean();returnsqrt(a*b);}4、//sales.h#ifndef SALES_H_#define SALES_H_#include <stdexcept>#include <string>#include <cstring>#include <iostream>#include <cstdlib>using namespace std;class Sales{public:enum { MONTHS = 12 };classbad_index:publiclogic_error{private:int bi;public:explicitbad_index(int ix, const string &s = "Index error in Sales object\n");intbi_val()const { return bi; }virtual ~bad_index()throw(){}};explicit Sales(intyy = 0);Sales(intyy, const double *gr, int n);virtual ~Sales(){}int Year()const { return year; }virtual double operator[](inti)const;virtual double &operator[](inti);private:double gross[MONTHS];int year;};classLabeledSales :public Sales{public:classnbad_index :public Sales::bad_index{private:std::stringlbl;public:nbad_index(const string &lb, int ix,const string &s = "Index error in LabeledSales object\n");const string &label_val()const { return lbl; }virtual ~nbad_index()throw(){}};explicitLabeledSales(const string &lb = "none", intyy = 0);LabeledSales(const string &lb, intyy, const double *gr, int n);virtual ~LabeledSales(){}const string &Label()const { return label; }virtual double operator[](inti)const;virtual double &operator[](inti);private:string label;};#endif//sales.cpp#include "sales.h"Sales::bad_index::bad_index(int ix,const string &s) :logic_error(s), bi(ix){}Sales::Sales(intyy){year = yy;for (inti = 0; i< MONTHS; ++i)gross[i] = 0;}Sales::Sales(intyy, const double *gr, int n){year = yy;intlim = (n < MONTHS) ? n : MONTHS;inti;for (i = 0; i<lim; ++i)gross[i] = gr[i];for (; i< MONTHS; ++i)gross[i] = 0;}double Sales::operator[](inti)const{if (i< 0 || i>= MONTHS)throwbad_index(i);return gross[i];}double&Sales::operator[](inti){if (i< 0 || i>= MONTHS)throwbad_index(i);return gross[i];}LabeledSales::nbad_index::nbad_index(const string &lb, int ix,const string &s) :Sales::bad_index(ix, s){lbl = lb;}LabeledSales::LabeledSales(const string &lb, intyy) : Sales(yy){label = lb;}LabeledSales::LabeledSales(const string &lb, intyy, const double *gr, int n) : Sales(yy, gr, n) {label = lb;}doubleLabeledSales::operator[](inti)const{if (i< 0 || i>= MONTHS)thrownbad_index(Label(), i);return Sales::operator[](i);}double&LabeledSales::operator[](inti){if (i< 0 || i>= MONTHS)thrownbad_index(Label(), i);return Sales::operator[](i);}//use_sales.cpp#include "sales.h"int main(){double vals1[12] ={1220, 1100, 1122, 2212, 1232, 2334,2884, 2393, 3302, 2922, 3002, 3544};double vals2[12] ={12, 11, 22, 21, 32, 24,28, 29, 33, 29, 32, 35};Sales sales1(2011, vals1, 12);LabeledSalessales2("Blogstar", 2012, vals2, 12);Sales::bad_index *s;LabeledSales::nbad_index *l;cout<< "First try block:\n";try{inti;cout<< "Year = " << sales1.Year() <<endl;for (i = 0; i< 12; ++i){cout<< sales1[i] << ' ';if (i % 6 == 5)cout<<endl;}cout<< "Year = " << sales2.Year() <<endl;cout<< "Label = " << bel() <<endl;for (i = 0; i<= 12; ++i){cout<< sales2[i] << ' ';if (i % 6 == 5)cout<<endl;}cout<< "End of try block 1.\n";}catch (logic_error&bad){cout<<bad.what();if (l = dynamic_cast<LabeledSales::nbad_index *>(&bad)) {cout<< "Comany: " << l->label_val() <<endl;cout<< "bad index: " << l->bi_val() <<endl;}else if (s = dynamic_cast<Sales::bad_index *>(&bad))cout<< "bad index: " << s->bi_val() <<endl;}cout<< "\nNext try block:\n";try{sales2[2] = 37.5;sales1[20] = 23345;cout<< "End of try block 2.\n";}catch (logic_error&bad){cout<<bad.what();if (l = dynamic_cast<LabeledSales::nbad_index *>(&bad)){cout<< "Comany: " << l->label_val() <<endl;cout<< "bad index: " << l->bi_val() <<endl;}else if (s = dynamic_cast<Sales::bad_index *>(&bad))cout<< "bad index: " << s->bi_val() <<endl;}cout<< "done\n";system("pause");return 0;}。
第6章分支语句和逻辑运算符//ex6.1#include<iostream>#include<cctype>int main(){using namespace std;char ch;cin.get(ch);while (ch != '@'){if (!isdigit(ch)){if (isupper(ch))ch = tolower(ch);else if (islower(ch))ch = toupper(ch);cout << ch;}cin.get(ch);}return 0;}//ex6.2#include<iostream>const int Max = 10;int main(){using namespace std;double num[Max];int i = 0;cout << "Number 1: ";while (i < Max && cin >> num[i]){if (++i < Max)cout << "Number " << i+1 << ": ";}double total = 0.0;for (int j = 0; j < i; j++)total += num[j];double Average = total/i;cout << "Average = " << Average << endl;int q = 0;for (int j = 0; j < i; j++)if (num[j] > Average)q++;cout << q << " numbers > average.\n";return 0;}//ex6.3#include<iostream>int main(){using namespace std;char ch;cout << "Please enter one of the choice:\n"<< "c) carnivore p) pianist\n"<< "t) tree g) game\n";cin >> ch;while (ch != 'c' && ch != 'p' && ch != 't' && ch != 'g'){cout << "Please enter a c, p, t, or g: ";cin >> ch;}switch (ch){case'c' : cout << "A cat is a carnivore.\n";break;case'p' : cout << "Radu Lupu is a pianist.\n";break;case't' : cout << "A maple is a tree.\n";break;case'g' : cout << "Golf is a game.\n";break;default : cout << "The program shouldn't get here!\n";}return 0;}//ex6.4#include<iostream>const int strsize = 20;struct bop{char fullname[strsize];char title[strsize];char bopname[strsize];int preference;};int main(){using namespace std;bop member[5] = {{"Wimp Macho", "English Teacher", "DEMON", 0},{"Raki Rhodes", "Junior Programmer", "BOOM", 1},{"Celia Laiter", "Super Star", "MIPS", 2},{"Hoppy Hipman", "Analyst Trainee", "WATEE", 1},{"Pat Hand", "Police", "LOOPY", 2}};char ch;cout << "Benevolent Order of Programmers Report\n"<< "a. display by name b. display by title\n"<< "c. display by bopname d. display by preference\n"<< "q. quit\n";cout << "Enter your choice: ";while (cin >> ch && ch != 'q'){switch (ch){case'a': for (int i = 0; i < 5; i++)cout << member[i].fullname << endl;break;case'b': for (int i = 0; i < 5; i++)cout << member[i].title << endl;break;case'c': for (int i = 0; i < 5; i++)cout << member[i].bopname << endl;break;case'd': for (int i = 0; i < 5; i++){if (member[i].preference == 0)cout << member[i].fullname << endl;else if (member[i].preference == 1)cout << member[i].title << endl;elsecout << member[i].bopname << endl;}break;}cout << "Next choice: ";}cout << "Bye!" << endl;return 0;}//ex6.5#include<iostream>const double LEV1 = 5000;const double LEV2 = 15000;const double LEV3 = 35000;const double RATE1 = 0.10;const double RATE2 = 0.15;const double RATE3 = 0.20;int main(){using namespace std;double income, tax;cout << "Enter your annual income in tvarps: ";cin >> income;if (income <= LEV1)tax = 0;else if (income <= LEV2)tax = (income - LEV1) * RATE1;else if (income <= LEV3)tax = RATE1 * (LEV2 - LEV1) + RATE2 * (income - LEV2);elsetax = RATE1 * (LEV2 - LEV1) + RATE2 * (LEV3 - LEV2)+ RATE3 * (income - LEV3);cout << "You owe Neutronia " << tax << " tvarps in taxes.\n";return 0;}//ex6.6#include<iostream>#include<string>using namespace std;struct Patrons{string name;double money;};int main(){cout << "输入捐赠者的数目: ";int num;cin >> num;Patrons* ps = new Patrons[num];cout << "输入每一个捐赠者的姓名和款项:\n";for (int i=0; i<num; i++){cout << "输入第" << i+1 << "位姓名: ";cin >> ps[i].name;cout << "输入第" << i+1 << "位款项: ";cin >> ps[i].money;}cout << "Grand Patron\n";for (int i=0; i<num; i++){if (ps[i].money > 10000)cout << ps[i].name << endl;}cout << "\nPatron\n";for (int i=0; i<num; i++){if (ps[i].money <= 10000)cout << ps[i].name << endl;}return 0;}//ex6.7#include<iostream>#include<string>#include<cctype>int main(){using namespace std;string word;int vowel = 0;int consonant = 0;int other = 0;char ch;cout << "Enter words (q to quit):\n";cin >> word;while (word != "q"){ch = tolower(word[0]);if (isalpha(ch)){if (ch == 'a' || ch == 'e' || ch == 'i' || ch == 'o' || ch == 'u')vowel ++;elseconsonant ++;}elseother ++;cin >> word;}cout << vowel << " words beginning with vowel\n"<< consonant << " words beginning with consonants\n"<< other << " others\n";return 0;}//ex6.8#include<iostream>#include<fstream>#include<cstdlib>const int SIZE = 60;int main(){using namespace std;char filename[SIZE];ifstream inFile;cout << "Enter name of data file: ";cin.getline(filename, SIZE);inFile.open(filename);if (!inFile.is_open()){cout << "Could not open the file " << filename << endl;cout << "Program terminating.\n";exit(EXIT_FAILURE);}int count = 0;char ch;inFile >> ch;while (inFile.good()){count ++;inFile >> ch; // get next value}cout << count << " characters in " << filename << endl;inFile.close(); // finished with the filereturn 0;}//ex6.9#include<iostream>#include<string>#include<fstream>#include<cstdlib>const int SIZE = 60;using namespace std;struct Patrons{string name;double money;};int main(){char filename[SIZE];ifstream inFile;cout << "Enter name of data file: ";cin.getline(filename, SIZE);inFile.open(filename);if (!inFile.is_open()){cout << "Could not open the file " << filename << endl;cout << "Program terminating.\n";exit(EXIT_FAILURE);}int num;inFile >> num;inFile.get();Patrons* ps = new Patrons[num];for (int i = 0; i<num; i++){getline(inFile, ps[i].name);inFile >> ps[i].money;inFile.get();}cout << "\nGrand Patrons:\n";int count1 = 0;for (int i = 0; i < num; i++){if (ps[i].money > 10000){cout << ps[i].name <<endl;count1++;}}if (count1 == 0)cout << "none";cout << "\nPatrons:\n";int count2 = 0;for (int i = 0; i < num; i++){if (ps[i].money <= 10000){cout << ps[i].name <<endl;count2++;}}if (count2 == 0)cout << "none";delete [] ps;inFile.close();return 0;}第7章函数——C++的编程模块//ex7.1#include<iostream>double t_av(double x, double y);int main(){using namespace std;double x, y;double result;cout << "Please enter two numbers (0 to stop): ";while ((cin >> x >> y) && x != 0 && y != 0){result = t_av(x, y);cout << "调和平均数 = " << result << endl;cout << "Please enter two numbers (0 to stop): ";}return 0;}double t_av(double x, double y){return 2.0 * x * y / (x + y);}//ex7.2#include<iostream>const int MAX = 10;using namespace std;int fill_ar(double ar[], int limit);void show_ar(const double ar[], int n);double average(const double ar[], int n);int main(){double scores[MAX];int size = fill_ar(scores, MAX);show_ar(scores, size);if (size > 0)cout << "The average of scores is: "<< average(scores, size) << endl;return 0;}int fill_ar(double ar[], int limit){double temp;int i;for (i = 0; i < limit; i++){cout << "Enter score #" << i+1 << ": ";cin >> temp;if (!cin){cin.clear();while (cin.get() != '\n')continue;cout << "Bad input; enter a number: ";break;}if (temp < 0)break;ar[i] = temp;}return i;}void show_ar(const double ar[], int n){for (int i = 0; i < n; i++)cout << "score #" << i+1 << ": " << ar[i] << endl; }double average(const double ar[], int n){double sum = 0.0;for (int i = 0; i < n; i++)sum += ar[i];return sum / n;}//ex7.3#include<iostream>struct box{char maker[40];float height;float width;float length;float volume;};void set_box(box *);void show_box(box);int main(){using namespace std;box carton = {"Bingo Boxer", 2, 3, 5};set_box(&carton);show_box(carton);return 0;}void set_box(box * pb){pb->volume = pb->height * pb->length * pb->width;}void show_box(box b){using namespace std;cout << "Box maker: " << b.maker<< "\nheight: " << b.height<< "\nlwidth: " << b.width<< "\nlength: " << b.length<< "\nvolume: " << b.volume << endl;}//ex7.4#include<iostream>long double probability(unsigned numbers, unsigned picks);int main(){using namespace std;double total, choices, mtotal;long double probability1, probability2;cout << "Enter total number of game card choices and\n""number of picks allowed for the field:\n";while ((cin >> total >> choices) && choices < total){cout << "Enter total number of game card choices and\n""number of picks allowed for the mega:\n";if (!(cin >> mtotal))break;probability1 = probability(total, choices);probability2 = probability(mtotal, 1);cout << "The chances of getting all "<< choices << " picks is one in "<< probability1 << ".\n";cout << "The chances of getting the megaspot is one in "<< probability2 << ".\n";cout << "You have one chance in ";cout << probability1 * probability2;cout << " of winning.\n";cout << "Next set of numbers (q to quit): ";}cout << "bye\n";return 0;}long double probability(unsigned numbers, unsigned picks){long double result = 1.0;long double n;unsigned p;for (n = numbers, p = picks; p > 0; n--, p--)result = result * n / p;return result;}//ex7.5#include<iostream>long long int recure(int);int main(){using namespace std;int number;cout << "Enter a integer (q to stop): ";while (cin >> number){long long int result = recure(number);cout << number << "! = " << result << endl;cout << "Next:";}cout << "Done!" << endl;return 0;}long long int recure(int n){long long int result;if (n > 0)result = n * recure(n-1);elseresult = 1;return result;}//ex7.6#include<iostream>const int Size = 10;int Fill_array(double ar[], int n);void Show_array(const double ar[], int n); void Reverse_array(double ar[], int n);int main(){using namespace std;double values[Size];int len = Fill_array(values, Size);cout << "Array values:\n";Show_array(values, len);cout << "Array reversed:\n";Reverse_array(values, len);Show_array(values, len);cout << "All but end values reversed:\n";Reverse_array(values+1, len-2);Show_array(values, len);return 0;}int Fill_array(double ar[], int n){using namespace std;double temp;int i;for (i=0; i<n; i++){cout << "Enter value #" << i+1 << ": ";cin >> temp;if (!cin)break;ar[i] = temp;}cout << endl;return i;}void Show_array(const double ar[], int n){using namespace std;for (int i=0; i<n; i++)cout << "Property #" << i+1 << ": "<< ar[i] << endl;cout << endl;}void Reverse_array(double ar[], int n){double temp;for (int i=0,j=n-1; i<j; i++,j--){temp = ar[i];ar[i] = ar[j];ar[j] = temp;}}//ex7.7#include<iostream>const int Max = 5;double * fill_array(double * begin, double * end);void show_array(const double * begin, const double * end); void revalue(double r, double * begin, double * end);int main(){using namespace std;double properties[Max];double * pbegin = properties;double * pend = fill_array(pbegin, pbegin + Max);show_array(pbegin, pend);if (pend-pbegin > 0){cout << "Enter revaluation factor: ";double factor;while (!(cin >> factor)){cin.clear();while (cin.get() != '\n')continue;cout << "Bad input; Please enter a number: ";}revalue(factor, pbegin, pend);show_array(pbegin, pend);}cout << "Done.\n";return 0;}double * fill_array(double * begin, double * end){using namespace std;double temp;int i = 1;while (begin < end){cout << "Enter value #" << i << ": ";cin >> temp;if (!cin){cin.clear();while (cin.get() != '\n')continue;cout << "Bad input; input process terminated.\n";break;}else if (temp < 0)break;*begin = temp;begin++;i++;}return begin;}void show_array(const double * begin, const double * end){using namespace std;int i = 1;while (begin < end){cout << "Property #" << i << ": $";cout << *begin << endl;begin++;i++;}}void revalue(double r, double * begin, double * end){while (begin < end){*begin *= r;begin++;}}//ex7.8a#include<iostream>const int Seasons = 4;const char * Snames[] = {"Spring", "Summer", "Fall", "Winter"}; void fill(double ar[], int n);void show(double ar[], int n);int main(){using namespace std;double expenses[Seasons];fill(expenses, Seasons);show(expenses, Seasons);return 0;}void fill(double ar[], int n){using namespace std;for (int i=0; i<n; i++){cout << "Enter " << Snames[i] << " expenses: ";cin >> ar[i];}}void show(double ar[], int n){using namespace std;cout << "\nEXPENSES\n";double total = 0.0;for (int i=0; i<n; i++){cout << Snames[i] << ": $" << ar[i] <<endl;total += ar[i];}cout << "Total Expenses: $" << total << endl;}//ex7.8b(传递结构值)#include<iostream>const int Seasons = 4;struct data{double arr[Seasons];};const char * Snames[] = {"Spring", "Summer", "Fall", "Winter"}; data fill();void show(data);int main(){using namespace std;data expenses = fill();show(expenses);return 0;}data fill(){using namespace std;data expenses;for (int i=0; i<Seasons; i++)cout << "Enter " << Snames[i] << " expenses: ";cin >> expenses.arr[i];}return expenses;}void show(data expenses){using namespace std;cout << "\nEXPENSES\n";double total = 0.0;for (int i=0; i<Seasons; i++){cout << Snames[i] << ": $" << expenses.arr[i] <<endl;total += expenses.arr[i];}cout << "Total Expenses: $" << total << endl;}//ex7.8b(传递结构指针)#include<iostream>const int Seasons = 4;struct data{double arr[Seasons];};const char * Snames[] = {"Spring", "Summer", "Fall", "Winter"}; void fill(data * pd);void show(data * pd);int main(){using namespace std;data expenses;fill(&expenses);show(&expenses);return 0;}void fill(data * pd){using namespace std;for (int i=0; i<Seasons; i++)cout << "Enter " << Snames[i] << " expenses: ";cin >> pd->arr[i];}}void show(data * pd){using namespace std;cout << "\nEXPENSES\n";double total = 0.0;for (int i=0; i<Seasons; i++){cout << Snames[i] << ": $" << pd->arr[i] <<endl;total += pd->arr[i];}cout << "Total Expenses: $" << total << endl;}//ex7.9#include<iostream>using namespace std;const int SLEN = 30;struct student {char fullname[SLEN];char hobby[SLEN];int ooplevel;};int getinfo(student pa[], int n);void display1(student st);void display2(const student * ps);void display3(const student pa[], int n);int main(){cout << "Enter class size: ";int class_size;cin >> class_size;while (cin.get() != '\n')continue;student * ptr_stu = new student[class_size];int entered = getinfo(ptr_stu, class_size);for (int i = 0; i < entered; i++)display1(ptr_stu[i]);display2(&ptr_stu[i]);}display3(ptr_stu, entered);delete [] ptr_stu;cout << "Done\n";return 0;}// getinfo() has two arguments: a pointer to the first element of // an array of student structures and an int representing the// number of elements of the array. The function solicits and// stores data about students. It terminates input upon filling// the array or upon encountering a blank line for the student// name. The function returns the actual number of array elements // filled.int getinfo(student pa[], int n){int num_array_elem = n;char tmp[SLEN];for (int i = 0; i < n; ++i){cout << "Enter name: ";cin.getline(tmp, SLEN);bool blank_line = true;for (unsigned j = 0; j < strlen(tmp); ++j){if (!isspace(tmp[j])){blank_line = false;break;}}if (blank_line){num_array_elem = i;break;}strcpy(pa[i].fullname, tmp);cout << "Enter hobby: ";cin.getline(pa[i].hobby, SLEN);cout << "Enter ooplevel: ";cin >> pa[i].ooplevel;cin.get();}cout << endl;return num_array_elem;}// display1() takes a student structure as an argument// and displays its contentsvoid display1(student st){cout << st.fullname << '\t'<< st.hobby << '\t'<< st.ooplevel << endl;}// display2() takes the address of student structure as an// argument and displays the structure’¡¥s contentsvoid display2(const student * ps){cout << ps->fullname << '\t'<< ps->hobby << '\t'<< ps->ooplevel << endl;}// display3() takes the address of the first element of an array// of student structures and the number of array elements as// arguments and displays the contents of the structuresvoid display3(const student pa[], int n){for (int i = 0; i < n; ++i)cout << pa[i].fullname << '\t' << pa[i].hobby << '\t' <<pa[i].ooplevel << endl;}//ex7.10#include<iostream>double calculate(double x, double y, double (*pf)(double, double)); double add(double x, double y);double sub(double x, double y);double mean(double x, double y);int main(){using namespace std;double a, b;double (*pf[3])(double, double) = {add, sub, mean};char * op[3] = {"add", "sub", "mean"};cout << "Enter pairs of numbers (q to quit): ";while (cin >> a >> b){for (int i=0; i<3; i++){cout << op[i] << ": " << a << " and " << b << " = "<< calculate(a, b, pf[i]) << endl;}}}double calculate(double x, double y, double (*pf)(double, double)) {return (*pf)(x, y);}double add(double x, double y){return x + y;}double sub(double x, double y){return x - y;}double mean(double x, double y){return (x + y) / 2.0;}第8章函数探幽//ex8.1#include<iostream>void show(const char * ps, int n = 0);int main(){using namespace std;char * pstr = "Hello\n";show(pstr);int num;cout << "Enter a number: ";cin >> num;show(pstr, num);cout << "Done\n";return 0;}void show(const char * ps, int n){using namespace std;int lim = n;if (n == 0)lim = 1;for (int i=0; i<lim; i++)cout << ps;}//ex8.2#include<iostream>#include<string>using namespace std;struct CandyBar{string name;double weight;int hot;};void set(CandyBar & cb, char * ps, double w, int h); void show(const CandyBar & cb);int main(){using namespace std;CandyBar candy;char * p = "Millennium Munch";double x = 2.85;int y = 350;set(candy, p, x, y);show(candy);return 0;}void set(CandyBar & cb, char * ps, double w, int h){ = ps;cb.weight = w;cb.hot = h;}void show(const CandyBar & cb){cout << "Name: " << << endl<< "Weight: " << cb.weight << endl<< "Hot: " << cb.hot << endl;}//ex8.3#include<iostream>#include<string>#include<cctype>using namespace std;void str_to_upper(string & str);int main(){string str1;cout << "Enter a string (q to quit): ";while (getline(cin, str1) && str1!="q" && str1!="Q") {str_to_upper(str1);cout << str1 << endl;cout << "Next string (q to quit): ";}cout << "Bye.";return 0;}void str_to_upper(string & str){int limit = str.size();for (int i=0; i<limit; i++){if (isalpha(str[i]))str[i] = toupper(str[i]);}}// ex8.4#include<iostream>#include<cstring>// for strlen(), strcpy()using namespace std;struct stringy {char * str; // points to a stringint ct; // length of string (not counting '\0')};void show(const char *str, int cnt = 1);void show(const stringy & bny, int cnt = 1);void set(stringy & bny, const char * str);int main(void){stringy beany;char testing[] = "Reality isn't what it used to be.";set(beany, testing); // first argument is a reference,// allocates space to hold copy of testing,// sets str member of beany to point to the// new block, copies testing to new block,// and sets ct member of beany show(beany); // prints member string onceshow(beany, 2); // prints member string twicetesting[0] = 'D';testing[1] = 'u';show(testing); // prints testing string onceshow(testing, 3); // prints testing string thriceshow("Done!");return 0;}void show(const char *str, int cnt){while(cnt-- > 0)cout << str << endl;}}void show(const stringy & bny, int cnt){while(cnt-- > 0){cout << bny.str << endl;}}void set(stringy & bny, const char * str){bny.ct = strlen(str);bny.str = new char[bny.ct+1];strcpy(bny.str, str);}//ex8.5#include<iostream>const int Limit = 5;template <typename T>T max5(T ar[]);int main(){using namespace std;int ari[Limit] = {1, 2, 3, 5, 4};double ard[Limit] = {1.1, 2.2, 3.3, 5.5, 4.4};int maxi = max5(ari);double maxd = max5(ard);cout << "maxi = " << maxi << endl;cout << "maxd = " << maxd << endl;return 0;}template <typename T>T max5(T ar[]){T max = ar[0];for (int i=1; i<Limit; i++)if (max < ar[i])max = ar[i];}return max;}//ex8.6#include<iostream>template <typename T>T maxn(T ar[], int n);template <> const char* maxn(const char* ar[], int n);int main(){using namespace std;int ari[6] = {1, 2, 3, 4, 6, 5};double ard[4] = {1.1, 2.2, 4.4, 3.3};const char * ars[5] = {"a","bb","ccc","ddddd","eeee"};cout << "The max integer of array is: " << maxn(ari, 6) << endl;cout << "The max double of array is: " << maxn(ard, 4) << endl;cout << "The max string of array is: " << maxn(ars, 5)<<endl; }template <typename T>T maxn(T ar[], int n){T maxar = ar[0];for (int i=1; i<n; i++){if (maxar < ar[i])maxar = ar[i];}return maxar;}template <> const char* maxn(const char* ar[],int n) {const char * maxs = ar[0];for (int i=1; i<n; i++){if (strlen(maxs) < strlen(ar[i]))maxs = ar[i];}return maxs;}//ex8.7#include<iostream>template <typename T>T SumArrray(T arr[], int n);template <typename T>T SumArrray(T * arr[], int n);struct debts{char name[50];double amount;};int main(){using namespace std;int things[6] = {13, 31, 103, 301, 310, 130};struct debts mr_E[3] ={{"Ima Wolfe", 2400.0},{"Ura Foxe", 1300.0},{"Iby Stout", 1800.0}};double * pd[3];for (int i=0; i<3; i++)pd[i] = &mr_E[i].amount;cout << "Sum: Mr.E's counts of things: "<< SumArrray(things, 6) << endl;cout << "Sum: Mr.E's debts: "<< SumArrray(pd, 3) << endl;return 0;。
1、//Reverse.cpp#include <iostream>#include <string>using namespace std;boolisReverse(const string &s1, const string &s2);int main(){string words;cout<< "Enter a string (quit to quit): \n";while (cin>> words&&words != "quit"){stringrwords(words.rbegin(), words.rend());cout<< "words: " << words <<endl;if (isReverse(rwords, words))cout<< words << " is reverse words.\n";elsecout<< words << " is not reverse words.\n";cout<< "Enter a next words (quit to quit): \n";}system("pause");return 0;}boolisReverse(const string &s1, const string &s2){if (pare(s2))return false;elsereturn true;}2、//Reverse.cpp#include <iostream>#include <string>#include <cctype>using namespace std;boolisReverse(const string &s1, const string &s2); voidToLower(string &s1);int main(){string words;cout<< "Enter a string (quit to quit): \n";getline(cin, words);while (words != "quit"){ToLower(words);stringrwords(words.rbegin(), words.rend());cout<< "words: " << words <<endl;if (isReverse(rwords, words))cout<< words << " is reverse words.\n";elsecout<< words << " is not reverse words.\n";cout<< "Enter a next words (quit to quit): \n";getline(cin, words);}system("pause");return 0;}boolisReverse(const string &s1, const string &s2){if (pare(s2))return false;elsereturn true;}voidToLower(string &s1){unsignedinti = 0;while (i< s1.length()){if (isalpha(s1[i])){s1[i] = tolower(s1[i]);i++;}elses1.replace(i, s1.size(), s1, i + 1, s1.size());}}3、//hangman.cpp#include <iostream>#include <string>#include <cstdlib>#include <ctime>#include <cctype>#include <fstream>#include <vector>using namespace std;vector<string> wordlist;voidFillWord();int main(){srand(time(0));char play;cout<< "Will you play a word game? <y/n> ";cin>> play;play = tolower(play);FillWord();while (play == 'y'){string target = wordlist[rand() % wordlist.size()];int length = target.length();string attempt(length, '-');stringbadchars;int guesses = 6;cout<< "Guess my secret word. It has " << length<< " letters, and you guess\n"<< "one letter at a time. You get " << guesses<<" wrong guesses.\n";cout<< "Your word: " << attempt <<endl;while (guesses > 0 && attempt != target){char letter;cout<< "Guess a letter: ";cin>> letter;if (badchars.find(letter) != string::npos|| attempt.find(letter) != string::npos){cout<< "You already guessed that. Try again.\n";continue;}intloc = target.find(letter);if (loc == string::npos){cout<< "Oh,bad guess!\n";--guesses;badchars += letter;}else{cout<< "Good guess!\n";attempt[loc] = letter;loc - target.find(letter, loc + 1);while (loc != string::npos){attempt[loc] = letter;loc = target.find(letter, loc + 1);}}cout<< "Your word: " << attempt <<endl;if (attempt != target){if (badchars.length() > 0)cout<< "Bad choices: " <<badchars<<endl;cout<< guesses << " bad guesses left\n";}}if (guesses > 0)cout<< "That's right!\n";elsecout<< "Sorry, the word is " << target << ".\n";cout<< "Will you play another? <y/n> ";cin>> play;play = tolower(play);}cout<< "Bye\n";system("pause");return 0;}voidFillWord(){ifstream fin;string letter;fin.open("letters.txt");if (fin.is_open() == false){cerr<< "Can't open file. Bye.\n";exit(EXIT_FAILURE);}while (fin){fin>> letter;wordlist.push_back(letter);}fin.close();}//letters.txtapiary beetle cereal danger ensign florid garage healthinsult jackal keeper loaner manage nonce onset plaidquilt remote stolid train useful valid whence xenon yearn zippy4、//Reduce.cpp#include <iostream>#include <list>#include <algorithm>using namespace std;int reduce(long ar[], int n);voidoutlong(int n){ cout<< n << " "; }int main(){long a[10] = { 1, 3, 2, 4, 7, 6, 3, 4, 8, 10 };intnums = reduce(a, 10);cout<< "Numbers after reduce: " <<nums<<endl;system("pause");return 0;}int reduce(long ar[], int n){list<long>arr;arr.insert(arr.begin(), ar, ar + n);arr.sort();arr.unique();for_each(arr.begin(), arr.end(), outlong);cout<<endl;returnarr.size();}5、//Reduce.cpp#include <iostream>#include <list>#include <algorithm>#include <string>using namespace std;template<class T>int reduce(T ar[], int n);template<class T>voidoutlong(T n){ cout<< n << " "; }int main(){long a[10] = { 1, 3, 2, 4, 7, 6, 3, 4, 8, 10 };int nums1 = reduce(a, 10);cout<< "Numbers after reduce: " << nums1 <<endl;string b[10] = { "qwe", "qwe", "ret", "tyu", "dfg", "jkl", "iok", "kjl", "ads", "def" };int nums2 = reduce(b, 10);cout<< "Numbers after reduce: " << nums2 <<endl;system("pause");return 0;}template<class T>int reduce(T ar[], int n){list<T>arr;arr.insert(arr.begin(), ar, ar + n);arr.sort();arr.unique();for_each(arr.begin(), arr.end(), outlong<T>);cout<<endl;returnarr.size();}6、//bank.cpp#include <iostream>#include <cstdlib>#include <queue>#include <ctime>using namespace std;class Customer{private:long arrive;intprocesstime;public:Customer(){ arrive = processtime = 0; }void set(long when){processtime = rand() % 3 + 1;arrive = when;}long when()const{ return arrive; }intptime()const{ return processtime; }};typedef Customer Item;constint MIN_PER_HR = 60;boolnewcustomer(double x);int main(){srand(time(0));cout<< "Case Study: Bank of Heather Automatic Teller\n";cout<< "Enter maximum size of queue: ";intqs;cin>>qs;queue<Item> line;cout<< "Enter the number of simulation hours: ";int hours;cin>> hours;longcyclelimit = MIN_PER_HR*hours;cout<< "Enter the average number of customers per hour: ";doubleperhour;cin>>perhour;doublemin_per_cust;min_per_cust = MIN_PER_HR / perhour;Item temp;longturnaways = 0;long customers = 0;long served = 0;longsum_line = 0;intwait_time = 0;longline_wait = 0;for (int cycle = 0; cycle <cyclelimit; cycle++){if (newcustomer(min_per_cust)){if (line.size() == qs)turnaways++;else{customers++;temp.set(cycle);line.push(temp);}}if (wait_time<= 0 && !line.empty()){line.pop();wait_time = temp.ptime();line_wait += cycle - temp.when();served++;}if (wait_time> 0)wait_time--;sum_line += line.size();}if (customers > 0){cout<< "customers accepted: " << customers <<endl;cout<< " customers served: " << served <<endl;cout<< " turnaways: " <<turnaways<<endl;cout<< "average queue size: ";cout.precision(2);cout.setf(ios_base::fixed, ios_base::floatfield);cout<< (double)sum_line / cyclelimit<<endl;cout<< " average wait time: "<< (double)line_wait / served << " minutes\n"; }elsecout<< "No customers!\n";cout<< "Done!\n";system("pause");return 0;}boolnewcustomer(double x){return (rand()*x / RAND_MAX < 1);}7、//Lotto.cpp#include <vector>#include <iostream>#include <iterator>#include <algorithm>#include <ctime>using namespace std;vector<int> Lotto(int l1, int l2);void Show(int n);int main(){vector<int> winners;winners = Lotto(51, 6);for_each(winners.begin(), winners.end(), Show);system("pause");return 0;}vector<int> Lotto(int l1, int l2){vector<int>nums;vector<int> nums2;srand(time(0));for (inti = 0; i< l1; i++)nums.push_back(i);random_shuffle(nums.begin(), nums.end());for (inti = 0; i< l2; i++)nums2.push_back(nums[rand() % l1 + 1]);return nums2;}void Show(int n){cout<< "The winner is " << n <<endl;}8、//name.cpp#include <iostream>#include <string>#include <set>#include <algorithm>#include <iterator>int main(){using namespace std;ostream_iterator<string, char>out(cout, " ");string fname1;set<string> A;cout<< "Enter Mat's friends(quit to quit): \n";getline(cin, fname1);while (fname1 != "quit"){A.insert(fname1);getline(cin, fname1);}cout<< "Mat's friends: \n";copy(A.begin(), A.end(), out);cout<<endl;string fname2;set<string> B;cout<< "Enter Pat's friends(quit to quit): \n";getline(cin, fname1);while (fname1 != "quit"){B.insert(fname1);getline(cin, fname1);}cout<< "Pat's friends: \n";copy(B.begin(), B.end(), out);cout<<endl;cout<< "Union of Mat and Pat's friends: ";set_union(A.begin(), A.end(), B.begin(), B.end(), out);cout<<endl;system("pause");return 0;}9、//sorttime.cpp#include <iostream>#include <vector>#include <list>#include <ctime>#include <iterator>#include <algorithm>using namespace std;constint Size = 10000;int main(){clock_t start, end;vector<int> vi0(Size);list<int> li(Size);srand(time(0));for (inti = 0; i< Size; i++){vi0[i] = rand() % Size;}copy(vi0.begin(), vi0.end(), back_inserter(li));vector<int> vi(vi0);start = clock();sort(vi.begin(), vi.end());end = clock();cout<< "Time of Sort Vector:" << (double)(end - start) / CLOCKS_PER_SEC <<endl;start = clock();li.sort();end = clock();cout<< "Time of Sort List:" << (double)(end - start) / CLOCKS_PER_SEC <<endl;copy(vi0.begin(), vi0.end(), back_inserter(li));start = clock();copy(li.begin(), li.end(), back_inserter(vi));sort(vi.begin(), vi.end());copy(vi.begin(), vi.end(), back_inserter(li));end = clock();cout<< "Time of Sort List2:" << (double)(end - start) / CLOCKS_PER_SEC <<endl;system("pause");return 0;}10、//vect.cpp#include <iostream>#include <string>#include <vector>#include <algorithm>#include <memory>#include <cstdlib>using namespace std;struct Review{string title;int rating;double price;};bool operator<(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2); boolworseThan(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2); boolbetterThan(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2); boolworseThanP(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2); boolbetterThanP(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2); boolFillReview(shared_ptr<Review>&rr);shared_ptr<Review>make_Review();voidShowReview(shared_ptr<Review>&rr);int main(){vector<shared_ptr<Review>> books;shared_ptr<Review>temp(new Review);while (FillReview(temp)){books.push_back(temp);temp = make_Review();}if (books.size() > 0){vector<shared_ptr<Review>>sbook(books);cout<< "Thank you. You entered the following:\n"<<books.size() << " ratings:\n" << "Rating\tBook\tPrice\n";for_each(books.begin(), books.end(), ShowReview);charch;cout<< "Enter measures of sort:\no to old";cout<< "t to title, r to down rating,\nR to up rating""p to down price,P to up price, f(F) to shuffle,\nq to quit:";cin>>ch;while (tolower(ch) != 'q'){switch (ch){case'o':cout<< "Not Sort:\nRating\tBook\tPrice\n";for_each(books.begin(), books.end(), ShowReview);break;case't':sort(sbook.begin(), sbook.end());cout<< "Sorted by title:\nRating\tBook\tPrice\n";for_each(sbook.begin(), sbook.end(), ShowReview);break;case'r':sort(sbook.begin(), sbook.end(), worseThan);cout<< "Sorted by down rating:\nRating\tBook\tPrice\n";for_each(sbook.begin(), sbook.end(), ShowReview);break;case'R':sort(sbook.begin(), sbook.end(), betterThan);cout<< "Sorted by up rating:\nRating\tBook\tPrice\n";for_each(sbook.begin(), sbook.end(), ShowReview);break;case'p':sort(sbook.begin(), sbook.end(), worseThanP);cout<< "Sorted by down price:\nRating\tBook\tPrice\n";for_each(sbook.begin(), sbook.end(), ShowReview);break;case'P':sort(sbook.begin(), sbook.end(), betterThanP);cout<< "Sorted by up price:\nRating\tBook\tPrice\n";for_each(sbook.begin(), sbook.end(), ShowReview);break;case'F':case'f':random_shuffle(sbook.begin(), sbook.end());cout<< "After shuffling:\nRating\tBook\n";for_each(sbook.begin(), sbook.end(), ShowReview);break;default:cout<< "Error input!Input again!";break;}cout<< "Enter the next measures:\no to old";cout<< "t to title, r to down rating,\nR to up rating""p to down price,P to up price, q to quit:";cin>>ch;}}elsecout<< "No entries. ";cout<< "Bye.\n";system("pause");return 0;}bool operator<(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2) {if (r1->title < r2->title)return true;else if (r1->title == r2->title&&r1->rating < r2->rating)return true;elsereturn false;}boolworseThan(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2) {if (r1->rating < r2->rating)return true;elsereturn false;}boolbetterThan(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2) {if (r1->rating > r2->rating)return true;elsereturn false;}boolworseThanP(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2) {if (r1->price < r2->price)return true;elsereturn false;}boolbetterThanP(constshared_ptr<Review>&r1, constshared_ptr<Review>&r2) {if (r1->price > r2->price)return true;elsereturn false;}shared_ptr<Review>make_Review(){returnshared_ptr<Review>(new Review);}boolFillReview(shared_ptr<Review>&rr){cout<< "Enter book title (quit to quit): ";getline(cin, rr->title);if (rr->title == "quit")return false;cout<< "Enter book rating: ";cin>>rr->rating;cout<< "Enter book price: ";cin>>rr->price;if (!cin)return false;while (cin.get() != '\n')continue;return true;}voidShowReview(shared_ptr<Review>&rr){cout<<rr->rating << "\t" <<rr->title << "\t" <<rr->price <<endl;}。
第10章1、//Customs.h#include <stdio.h>#include <tchar.h>#include <string>#include <iostream>using namespace std;class Customs{private:string name;string accnum;double balance;public:Customs(const string &client, const string &num, double bal = 0.0);~Customs();void show()const;bool deposit(double cash);bool withdraw(double cash);};//Customs.cpp#include "Customs.h"Customs::Customs(const string &client,const string &num, double bal) {accnum = num;name = client;balance = bal;}Customs::~Customs(){}bool Customs::deposit(double cash){if (cash <= 0){cout << "Deposit must greater than zero\n";return false;}else{cout << "Custom deposits $" << cash << " dolars.\n";balance += cash;return true;}}bool Customs::withdraw(double cash){if (cash <= 0 || (balance - cash) < 0){cout << "Withdraw money error, must less than balance and greater than zero\n";return false;}else{cout << "Custom withdraws $" << cash << " dolars\n";balance -= cash;return true;}}void Customs::show()const{cout << "Account custom's name is " << name << endl;cout << "Account number is " << accnum << endl;cout << "Custom's balance is " << balance << endl;}//main.cpp#include "Customs.h"int main(){double input, output;char ch;Customs custom=Customs("Jacky","Jc",3000.32);custom.show();cout << "Please enter A to deposit balance ,\n"<< "P to withdraw balance, or Q to quit.: ";while (cin >> ch && toupper(ch)!='Q'){while (cin.get() != '\n')continue;if (!isalpha(ch)){cout << '\a';continue;}switch (ch){case'A':case'a':cout << "Enter a account number to deposit: ";cin >> input;if (!custom.deposit(input))cout << "Add error\n";elsecout << "Add success\n";break;case'P':case'p':cout << "Enter a account number to withdraw: ";cin >> output;if (!custom.withdraw(output))cout << "Withdraw error\n";elsecout << "Withdraw success\n";break;}custom.show();cout << "Please enter A to deposit balance ,\n"<< "P to withdraw balance, or Q to quit: ";}cout << "Bye\n";cin.get();cin.get();return 0;}2、//person.h#ifndef PERSON_H_#define PERSON_H_#include <iostream>#include <stdio.h>#include <tchar.h>#include <string>using namespace std;class Person{private:static const int Person::LIMIT = 25;string lname;char fname[LIMIT];public:Person(){ lname = ""; fname[0] = '\0'; }Person(const string &ln, const char *fn = "Heyyou");void Show()const;void FormalShow()const;};#endif//person.cpp#include "person.h"Person::Person(const string &ln, const char *fn){lname = ln;strncpy_s(fname, fn, LIMIT);fname[LIMIT] = '\0';}void Person::Show()const{cout << fname << " " << lname;}void Person::FormalShow()const{cout << lname << ", " << fname; }//usePerson.cpp#include "person.h"int main(){Person one;Person two("Smythecraft");Person three("Dimwiddy", "Sam");one.Show();cout << endl;one.FormalShow();cout << endl;two.Show();cout << endl;two.FormalShow();cout << endl;three.Show();cout << endl;three.FormalShow();cout << endl;cin.get();return 0;}3、//golf.h#ifndef GOLF_H_#define GOLF_H_#include <iostream>#include <string>using namespace std;class golf{private:static const int Len = 40;char fullname[Len];int handicap;public:golf();golf(const char *name, int hc = 0);golf(golf &g);~golf();void handicapf(int hc);void show()const;};#endif//golf.cpp#include "golf.h"golf::golf(){}golf::golf(const char *name, int hc){strncpy_s(fullname, name, Len);fullname[Len] = '\0';handicap = hc;}golf::golf(golf &g){strncpy_s(this->fullname, g.fullname, Len);this->handicap = g.handicap;}golf::~golf(){}void golf::handicapf( int hc){handicap = hc;}void golf::show()const{cout << fullname << ", " << handicap << endl; }//main.cpp#include "golf.h"int main(){char name[40] = "\0";int no;cout << "Enter a name: ";cin.getline(name, 40);cout << "Enter a level: ";cin >> no;golf ann(name, no);ann.show();golf andy = golf(ann);andy.show();cin.get();cin.get();return 0;}4、//Sales.h#ifndef SALE_H_#define SALE_H_#include <iostream>#include <string>using namespace std;namespace SALES{class Sales{private:static const int QUARTERS = 4;double sales[QUARTERS];double average;double max;double min;public:Sales();Sales(const double *ar);Sales(Sales &s);~Sales();void showSales()const;};}#endif//Sales.cpp#include "Sales.h"using namespace SALES;Sales::Sales(){sales[QUARTERS] = '\0';average = 0.0;max = 0.0;min = 0.0;}Sales::Sales(const double *ar){double sum=0.0;for (int i = 0; i < QUARTERS; i++){sales[i] = ar[i];sum += sales[i];}average = sum / QUARTERS;max = sales[0];for (int i = 0; i < QUARTERS-1; i++){if (sales[i] < sales[i + 1])max = sales[i + 1];}min = sales[0];for (int i = 0; i < QUARTERS-1; i++){if (sales[i] > sales[i + 1])min = sales[i + 1];}}Sales::Sales(Sales &s){for (int i = 0; i < QUARTERS; i++)this->sales[i] = s.sales[i];this->average = s.average;this->max = s.max;this->min = s.min;}Sales::~Sales(){}void Sales::showSales()const{cout << "The sales number is \n";for (int i = 0; i < QUARTERS; i++){cout << sales[i] << " ";}cout << endl;cout << "The sales average is " << average << endl;cout << "The sales max is " << max << endl;cout << "The sales min is " << min << endl;}//main.cpp#include "Sales.h"using namespace SALES;int main(){double nums[4];cout << "Please enter four numbers: \n";for (int i = 0; i < 4; i++)cin >> nums[i];Sales sn(nums);sn.showSales();Sales sn1(sn);sn1.showSales();cin.get();cin.get();return 0;}5、//stack.h#ifndef STACK_H_#define STACK_H_#include <iostream>#include <string>#include <stdio.h>using namespace std;struct customer{char fullname[35];double payment;};typedef struct customer Item;class Stack{private:enum{ MAX = 10 };Item items[MAX];double sum;int top;public:Stack();~Stack();bool isempty()const;bool isfull()const;bool push(const Item &item);bool pop(Item &item);};#endif#include "stack.h"Stack::Stack(){top = 0;sum = 0.0;}Stack::~Stack(){}bool Stack::isempty()const{return top == 0;}bool Stack::isfull()const{return top == MAX;}bool Stack::push(const Item &item) {if (top < MAX){items[top++] = item;return true;}elsereturn false;}bool Stack::pop(Item &item){if (top > 0){item = items[--top];sum += item.payment;cout << sum << endl;return true;}return false;}//main.cpp#include "stack.h"int main(){Stack st;char ch;Item cs;cout << "Please enter A to add a purchase order,\n"<< "P to process a PO, or Q to quit.\n";while (cin >> ch && toupper(ch) != 'Q'){while (cin.get() != '\n')continue;if (!isalpha(ch)){cout << '\a';continue;}switch (ch){case 'A':case 'a':cout << "Enter a PO number to add: ";cin >> cs.fullname;cin >> cs.payment;if (st.isfull())cout << "stack already full\n";elsest.push(cs);break;case 'P':case 'p':if (st.isempty())cout << "stack already empty\n";else{st.pop(cs);cout << "PO #" << cs.fullname << "popped\n";}break;}cout << "Please enter A to add a purchase order,\n"<< "P to process a PO, or Q to quit.\n";}cout << "Bye\n";cin.get();cin.get();return 0;}6、//Move.h#ifndef MOVE_H_#define MOVE_H_#include <stdio.h>#include <iostream>#include <string>using namespace std;class Move{private:double x;double y;public:Move(double a = 0, double b = 0);void showmove()const;Move add(const Move &m)const;void reset(double a = 0, double b = 0);};#endif//Move.cpp#include "Move.h"Move::Move(double a, double b){x = a;y = b;}void Move::showmove()const{cout << "x = " << x << endl;cout << "y = " << y << endl;}Move Move::add(const Move &m)const {Move xy_add;xy_add.x = m.x + this->x;xy_add.y = m.y + this->y;return xy_add;}void Move::reset(double a, double b) {x = a;y = b;}//main.cpp#include "Move.h"int main(){Move xy0(1, 1);xy0.showmove();Move xy1;xy1 = Move(2, 2);xy1.showmove();xy1 = xy1.add(xy0);xy1.showmove();xy1.reset(2.5, 2.5);xy1.showmove();cin.get();return 0;}7、//plorg.h#ifndef PLORG_H_#define PLORG_H_#include <iostream>#include <string>#include <stdio.h>using namespace std;class plorg{private:static const int len = 19;char fullname[len];int CI;public:plorg(const char *name = "Plorga", int ci = 50);~plorg();void p_fix(int ci);void show()const;};#endif//plorg.cpp#include "plorg.h"plorg::plorg(const char *name, int ci){strncpy_s(fullname, name, len);CI = ci;}plorg::~plorg(){}void plorg::p_fix(int ci){CI = ci;}void plorg::show()const{cout << fullname << ", " << CI << endl; }//main.cpp#include "plorg.h"int main(){plorg pl;pl.show();pl.p_fix(32);pl.show();plorg pll("Plorgb", 27);pll.show();pll.p_fix(32);pll.show();cin.get();return 0;}8、//list.h#ifndef LIST_H_#define LIST_H_#include <iostream>#include <string>#include <stdio.h>using namespace std;typedef unsigned long Item;class List{private:enum { MAX = 10 };Item items[MAX];int head;int rear;public:List();bool isempty()const;bool isfull()const;bool add(const Item &item);bool cut(Item &item);void show()const;void visit(void(*pf)(Item &)); };#endif//list.cpp#include "list.h"List::List(){head = 0;rear = 0;}bool List::isempty()const{return rear == head;}bool List::isfull()const{return rear - head == MAX; }bool List::add(const Item &item) {if (rear < MAX){items[rear++] = item;return true;}elsereturn false;}bool List::cut(Item &item){if (rear < MAX){item = items[--rear];return true;}elsereturn false;}void List::show()const{for (int i = head; i < rear; i++)cout << items[i] << ", ";cout << endl;}void List::visit(void(*pf)(Item &)){for (int i = 0; i < rear; i++)(*pf)(items[i]);}//main.cpp#include "list.h"void show_s(Item & item);int main(){List st;char ch;unsigned long po;unsigned long *p = &po;cout << "Please enter A to add a purchase order,\n"<< "P to process a PO, or Q to quit.\n";while (cin >> ch && toupper(ch) != 'Q'){while (cin.get() != '\n')continue;if (!isalpha(ch)){cout << '\a';continue;}switch (ch){case 'A':case 'a':cout << "Enter a PO number to add: ";cin >> po;if (st.isfull())cout << "stack already full\n";elsest.add(po);break;case 'P':case 'p':if (st.isempty())cout << "stack already empty\n";else{st.cut(po);cout << "PO #" << po << "popped\n";}break;case 'V':case 'v':st.visit(show_s);}cout << "Please enter A to add a purchase order,\n"<< "P to process a PO, or Q to quit.\n";}st.show();cout << "Bye\n";cin.get();cin.get();return 0;}void show_s(Item &item){item += 100;cout << item << endl;}。
注意:下面的勘误中,红色字体为修改后的文字,提请各位读者注意。
1.第6页,” 1.6语言标准”中的第3行,将1987年修改为1978年。
2.第22页,” 2. main()函数”中的第1行,int main (void)后面的分号(;)删除。
3.第24页,“5. 声明”的第10行,也就是一个变量、函数或其他实体的名称。
4.第27页,图2.3中,下划线应该只包含括号中的内容;第2段的第4行,而不是存储在源代码中的指令。
5.第30页,“2.5.4 打印多个值”的第4行,双引号后面的第1个变量。
6.第34页,“2.7.3 程序状态”第2段的第4行,要尽量忠实于代码来模拟。
7.第35页,“2.10 本章小结”第2段的第1句,声明语句为变量指定变量名,并标识该变量中存储的数据类型;本页倒数第2行,即检查程序每执行一步后所有变量的值。
8.第37页,“2.12 编程练习”中第1题,把你的名和姓打印在一行……把你的名和姓分别打印在两行……把你的名和姓打印在一行……把示例的内容换成你的名字。
9.第40页,第1行,用于把英磅常衡盎司转换为……10.第44页,“3.4 C语言基本数据类型”的第1句,本节将详细介绍C语言的基本属性类型……11.第46页,“5. 八进制和十六进制”的第4句,十六进制数3的二进制数是0011,十六进制数5的二进制数是0101;“6.显示八进制和十六进制”的第1句,既可以使用也可以显示不同进制的数;将“回忆一下……程序在执行完毕后不会立即关闭执行窗口”放到一个括号里。
12.第47页,“2.使用多种整数类型的原因”第3句,过去的一台运行Windows 3.x的机器上。
13.第53页,图 3.5下面的第4行“上面最后一个例子(printf(“Gramps sez, \”a \\ is abackslash.\”\n”);)”14.第56页,正文的第2行和第4行应该分别为printf(“me32 = %“ “d” “\n”, me32); printf(“me32 = %d\n”, me32);15.第61页,“无符号类型”的最后1句,相当于unsigned int(即两者之间添加一个空格)。
================================================================= *** 《C++ Primer Plus (第6 版)中文版》勘误表***作者:yangyang.gnu联系:yangyang.gnu@时间:2013-9-24================================================================= P268错误: free_throws * pt;修正: free_throws * pt = new free_throws;P291错误:在这两个模板函数中,recycle<blot *>(blot *) 被认为是更具体的修正:在这两个模板函数中,recycle<blot>(blot *) 被认为是更具体的P337错误: staticconst LIMIT = 25;修正: staticconst unsigned LIMIT = 25;P386错误:t4 = t1 + t2 + t3 先转换为t4 = t1.operator+(t2 + t3) 再转换为t4 =t1.operator+(t2.operator+(t3))修正:t4 = t1 + t2 + t3 先转换为t4 = t1.operator+(t2) + t3 再转换为t4 =t1.operator+(t2).operator+(t3)P387错误:.*:成员指针运算符修正:->:成员指针运算符P428错误:String boston("Boston");修正:StringBadboston("Boston");P431错误:然后程序使用重载运算符>>列出了这些对象修正:然后程序使用重载运算符<<列出了这些对象P439错误:最简单的办法是使用标准的trcmp()函数修正:最简单的办法是使用标准的strcmp()函数P440错误:means.operator[][0] = 'r';修正:means.operator[](0) = 'r';P439错误:因为内置的>运算符返回的是一个布尔值修正:因为内置的<运算符返回的是一个布尔值P478错误:Cow(const Cow c& );修正:Cow(const Cow & c);P478错误:提供一个Stringlow()成员函数修正:提供一个stringlow()成员函数错误:提供String()成员函数修正:提供stringup()成员函数P505错误: 这意味着,即使基类不需要显式析构函数提供服务,也不应该依赖于默认构造函数修正: 这意味着,即使基类不需要显式析构函数提供服务,也不应该依赖于默认构造析构P508错误:半长轴修正:长半轴P510错误:void Move(intnx, ny) = 0修正:virtual void Move(intnx, ny) = 0P525错误:Star::Star double() {...}Star::Star const char * () {...}修正:Star::operator double() {...}Star::operator const char * () {...}P529错误:派生类的有元函数修正:派生类的友元函数P532错误:Cd(char * s1, char * s2, int n, double x);修正:Cd(const char * s1, const char * s2, int n, double x);P532错误:派生出一个Classic 类,并添加一组char 成员修正:派生出一个Classic 类,并添加一个char 数组成员P532错误:copy.Report()修正:copy.Report();P535错误:所有元素度被初始化为指定值的数组修正:所有元素都被初始化为指定值的数组P544错误:例如,在类声明中提出可以使用average()函数。
第二章:开始学习C++//ex2.1--display your name and a ddress#include<iostream>int main(void){using namespace std;cout<<"My name is liao chunguang and I live in hunan chenzhou.\n〞;}the furlong units to yard uints-把浪单位换位码单位#include<iostream>double fur2yd(double);int main(){using namespace std;cout<<"enter the distance measured by furlong u nits:";double fur;cin>>fur;cout<<"convert the furlong to y ard"<<endl;double yd;yd=fur2yd(fur);cout<<fur<<" furlong is "<<yd<<" yard"<<endl;return 0;}double fur2yd(double t){return 220*t;}每个函数都被调用两次#include<iostream>void mice();void see();using namespace std;int main(){mice();mice();see();see();return 0;}void mice(){cout<<"three blind mice"<<endl;}void see(){cout<<"see how they run"<<endl;}#include<iostream>int main(){using namespace std;cout<<"Enter your age:";int age;cin>>age;int month;month=age*12;cout<<age<<" years is "<<month<<" months"<<endl;return 0;}the Celsius valve to Fahrenheit value#include<iostream>double C2F(double);int main(){using namespace std;cout<<"please enter a Celsius value:";double C;cin>>C;double F;F=C2F(C);cout<<C<<" degrees Celsius is "<<F<<" degrees Fahrenheit."<<endl; return 0;}double C2F(double t){return 1.8*t+32;}the light years valve to astronomical units--把光年转换为天文单位#include<iostream>double convert(double);//函数原型int main(){using namespace std;cout<<"Enter the number of light y ears:";double light_years;cin>>light_years;double astro_units;astro_units=convert(light_years);cout<<light_years<<" light_years = "<<astro_units<<" astronomical units."<<endl; return 0;}double convert(double t){return 63240*t;//1 光年=63240 天文单位}显示用户输入的小时数和分钟数#include<iostream>void show();main(){using namespace std;show();return 0;}void show(){using namespace std;int h,m;cout<<"enter the number of hours:";cin>>h;cout<<"enter the number of minutes:";cin>>m;cout<<"Time:"<<h<<":"<<m<<endl;}第三章:处理数据//ex3.1—将身高用英尺(feet)和英寸(inch)表示#include<iostream>const int inch_per_feet=12;// const 常量--1feet=12inches--1 英尺=12 英寸int main(){using namespace std;cout<<"please enter your height in inches:\b\b\b";// \b 表示为退格字符int ht_inch;cin>>ht_inch;int ht_feet=ht_inch/inch_per_feet;//取商int rm_inch=ht_inch%inch_per_feet;//取余cout<<"your height is "<<ht_feet<<" feet,and "<<rm_inch<<" inches\n";return 0;}计算相应的body mass index〔体重指数〕#include<iostream>const int inch_per_feet=12;const double meter_per_inch=0.0254;const double pound_per_kilogram=2.2;int main(){using namespace std;cout<<"Please enter your height:"<<endl;cout<<"First,enter your height of feet part〔输入你身高的英尺局部〕:_\b";int ht_feet;cin>>ht_feet;cout<<"Second,enter your height of inch p art〔输入你身高的英寸局部〕:_\b";int ht_inch;cin>>ht_inch;cout<<"Now,please enter your weight in pound:\b\b\b";double wt_pound;cin>>wt_pound;int inch;inch=ht_feet*inch_per_feet+ht_inch;double ht_meter;ht_meter=inch*meter_per_inch;double wt_kilogram;wt_kilogram=wt_pound/pound_per_kilogram;cout<<endl;cout<<"Your pensonal body information as follows:"<<endl; cout<<"身高:"<<inch<<"(英尺inch)\n"<<"身高:"<<ht_meter<<"(米meter)\n"<<"体重:"<<wt_kilogram<<"(千克kilogram)\n";double BMI;BMI=wt_kilogram/(ht_meter*ht_meter);cout<<"your Body Mass Index(体重指数) is "<<BMI<<endl;return 0;}以度,分,秒输入,以度输出#include<iostream>const int minutes_per_degree=60;const int seconds_per_minute=60;int main(){using namespace std;cout<<"Enter a latitude in degrees,minutes,and s econds:\n";cout<<"First,enter the d egrees:";int degree;cin>>degree;cout<<"Next,enter the minutes of arc:";int minute;cin>>minute;cout<<"Fianlly,enter the seconds of arc:";int second;cin>>second;double show_in_degree;show_in_degree=(double)degree+(double)minute/minutes_per_degree+(double)second/mi nutes_per_degree/seconds_per_minute;cout<<degree<<" degrees,"<<minute<<" minutes,"<<second<<"seconds ="<<show_in_degree<<" degrees\n";return 0;}#include<iostream>const int hours_per_day=24;const int minutes_per_hour=60;const int seconds_per_minute=60;int main(){using namespace std;cout<<"Enter the number of seconds:";long seconds;cin>>seconds;int Day,Hour,Minute,Second;Day=seconds/seconds_per_minute/minutes_per_hour/hours_per_day;Hour=seconds/seconds_per_minute/minutes_per_hour%hours_per_day;Minute=seconds/seconds_per_minute%minutes_per_hour;Second=seconds%seconds_per_minute;cout<<seconds<<"seconds = "<<Day<<" days,"<<Hour<<" hours,"<<Minute<<" minutes,"<<Second<<" seconds\n";return 0;}#include<iostream>int main(){using namespace std;cout<<"Enter the world population:";long long world_population;cin>>world_population;cout<<"Enter the population of the US:";long long US_population; cin>>US_population;double percentage;percentage=(double)US_population/world_population*100;cout<<"The population of the US is "<<percentage<<"% of the world population.\n"; return 0;}//ex3.6 汽车耗油量-美国(mpg)or 欧洲风格(L/100Km)#include<iostream>int main(){using namespace std;cout<<"Enter the miles of distance you have driven:";double m_distance;cin>>m_distance;cout<<"Enter the gallons of gasoline you have used:";double m_gasoline;cin>>m_gasoline;cout<<"Your car can run "<<m_distance/m_gasoline<<" miles per gallon\n";cout<<"Computing by European style:\n";cout<<"Enter the distance in k ilometers:";double k_distance;cin>>k_distance;cout<<"Enter the petrol in l iters:";double k_gasoline;cin>>k_gasoline;cout<<"In European style:"<<"your can used "<<100*k_gasoline/k_distance<<" liters of petrol per 100 kilometers\n";return 0;}//ex3.7 automobile gasoline consumption-耗油量--欧洲风格(L/100Km)转换成美国风格(mpg) #include<iostream>int main(){using namespace std;cout<<"Enter the automobile gasoline consumption figure in\n"<<"European style(liters per 100 k ilometers):";double Euro_style;cin>>Euro_style;cout<<"Converts to U.S. style(miles per gallon):"<<endl;cout<<Euro_style<<" L/100Km = "<<62.14*3.875/Euro_style<<" mpg\n";return 0;}// Note that 100 kilometers is 62.14 miles, and 1 gallon is 3.875 liters.//Thus, 19 mpg is about L/100Km, and 27 mpg is about L/100Km. Enter theautomobile gasoline consumption figure inEuropean style(liters per 100 Converts to U.S.style(miles per gallon):mpgPress any key to continue// ex3.7 automobile gasoline consumption-耗油量--美国风格(mpg)转换成欧洲风格(L/100Km) #include<iostream>int main(){using namespace std;cout<<"Enter the automobile gasoline consumption figure in\n"<<"U.S. style(miles per gallon):";double US_style;cin>>US_style;cout<<"Converts to European style(miles per gallon):"<<endl;cout<<US_style<<" mpg = "<< 62.14*3.875/US_style<<"L/100Km\n";return 0;}// Enter the automobile gasoline consumption figure inU.S. style(miles per gallon):19Converts to European style(miles per gallon):19 mpg =Press any key to continue第四章复合类型//ex4.1 display the information of student#include<iostream>const int Asize=20;using namespace std;struct student//定义结构描述{char firstname[Asize];char lastname[Asize];char grade;int age;};void display(student);//函数原型放在结构描述后int main(){cout<<"what is your first name?"<<endl;student lcg;//创立结构变量〔结构数据对象〕cin.getline(lcg.firstname,Asize);cout<<"what is your last name?"<<endl;cin.getline(stname,Asize);cout<<"what letter grade do you d eserve?"<<endl;cin>>lcg.grade;cout<<"what is your age?"<<endl;cin>>lcg.age;display(lcg);return 0;}void display(student name){cout<<"Name: "<<name.firstname<<","<<stname<<endl;cout<<"Grade:"<<char(name.grade+1)<<endl;cout<<"Age:"<<name.age<<endl;}use the string-class instead of char-array#include<iostream>#include<string>int main(){using namespace std;string name,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;}//有时候会遇到需要按下两次回车键才能正确的显示结果,这是的一个BUG,更改如下:else if (_Tr::eq((_E)_C, _D)){_Chg = true;_I.rdbuf()->sbumpc();//修改后的break; }输入其名和姓,并组合显示#include<iostream>#include<cstring>const int Asize=20;int main(){using namespace std;char fname[Asize];char lname[Asize];char fullname[2*Asize+1];cout<<"Enter your first name:";//输入名字,存储在fname[]数组中cin.getline(fname,Asize);cout<<"Enter your last name:";//输入姓,存储在lname[]数组中cin.getline(lname,Asize);strncpy(fullname,lname,Asize);//把姓lname 复制到fullname 空数组中strcat(fullname,", ");//把“,〞附加到上述fullname 尾部strncat(fullname,fname,Asize);//把fname 名字附加到上述fullname 尾部fullname[2*Asize]='\0';//为防止字符型数组溢出,在数组结尾添加结束符cout<<"Here's the information in a single string:"<<fullname<<endl;//显示组合结果return 0;}#define _CRT_SECURE_NO_WARNINGS#include <iostream>#include <cstring>const int Asize = 20;int main(){using namespace std;char firstname[Asize];char lastname[50];cout << "Enter your first name: ";cin.getline(firstname,Asize);cout << "Enter your last name: ";cin.getline(lastname,50);strcat(lastname,", ");strncat(lastname,firstname,Asize);cout << "Here's the information in a single string: "<< lastname <<endl;return 0;}//ex4.4 使用string 对象存储、显示组合结果#include<iostream>#include<string>int main(){using namespace std;string fname,lname,attach,fullname;cout<<"Enter your first name:";getline(cin,fname);//note:将一行输入读取到string 类对象中使用的是getline(cin,str)//它没有使用句点表示法,所以不是类方法cout<<"Enter your last name:";getline(cin,lname);attach=", ";fullname=lname+attach+fname;cout<<"Here's the information in a single string:"<<fullname<<endl;return 0;}//ex4.5 declare a struct and initialize it 声明结果并创立一个变量#include<iostream>const int Asize=20;struct CandyBar{char brand[Asize];double weight;int calory;int main(){using namespace std;CandyBar snack={"Mocha Munch",2.3,350};cout<<"Here's the information of snack:\n";cout<<"brand:"<<snack.brand<<endl;cout<<"weight:"<<snack.weight<<endl;cout<<"calory:"<<snack.calory<<endl;return 0;}结构数组的声明及初始化#include<iostream>const int Asize=20;struct CandyBar{char brand[Asize];double weight;int calory;};int main(){using namespace std;CandyBar snack[3]={{"Mocha Munch",2.3,350},{"XuFuJi",1.1,300},{"Alps",0.4,100}};for(int i=0;i<3;i++)//利用for 循环来显示snack 变量的内容{cout<<snack[i].brand<<endl<<snack[i].weight<<endl<<snack[i].calory<<endl<<endl;}return 0;}//ex4.7 pizza 披萨饼#include<iostream>#include<string>const int Size=20;struct pizza//声明结构char company[Size];double diameter;double weight;};int main(){using namespace std;pizza pie;//创立一个名为pie 的结构变量cout<<"What's the name of pizza company:";cin.getline(pie pany,Size);cout<<"What's the diameter of pizza:";cin>>pie.diameter;cout<<"What's the weight of pizza:";cin>>pie.weight; cout<<"company:"<<piepany<<endl;cout<<"diameter:"<<pie.diameter<<"inches"<<endl;cout<<"weight:"<<pie.weight<<"ounches"<<endl;return 0;}pizza pie 披萨饼使用new 创立动态结构#include<iostream>#include<string>const int Size=20;struct pizza//声明结构{char company[Size];double diameter;double weight;};int main(){using namespace std;pizza *pie=new pizza;//使用new 创立动态结构cout<<"What's the diameter of pizza:";cin>>pie->diameter; cin.get();//读取下一个字符cout<<"What's the name of pizza company:";cin.get(pie->company,Size);cout<<"What's the weight of pizza:";cin>>pie->weight;cout<<"diameter:"<<pie->diameter<<" inches"<<endl;cout<<"company:"<<pie->company<<endl;cout<<"weight:"<<pie->weight<<" ounches"<<endl;delete pie;//delete 释放内存return 0;}//ex.4.9 使用new 动态分配数组—方法1#include<iostream>#include<string>using namespace std;struct CandyBar{string brand;double weight;int calory;};int main(){CandyBar *snack= new CandyBar[3]; snack[0].brand="A";//单个初始化由new 动态分配的内存snack[0].weight=1.1;snack[0].calory=200;snack[1].brand="B";snack[1].weight=2.2;snack[1].calory=400;snack[2].brand="C";snack[2].weight=4.4;snack[2].calory=500;for(int i=0;i<3;i++){cout << " brand: " << snack[i].brand << endl;cout << " weight: " << snack[i].weight << e ndl;cout << " calorie: " << snack[i].calory << endl<<endl;}delete [] snack;return 0;}//ex.4.10 数组—方法1#include <iostream>int main(){using namespace std;const int Size = 3;int success[Size];cout<<"Enter your success of the three times 40 meters running:\n";cin >> success[0]>>success[1]>>success[2];cout<<"success1:"<<success[0]<<endl;cout<<"success2:"<<success[1]<<endl;cout<<"success3:"<<success[2]<<endl;double average=(success[0]+success[1]+success[2])/3;cout<<"average:"<<average<<endl;return 0;}//ex.4.10 array—方法2#include <iostream>#include <array>int main(){using namespace std;array<double,4>ad={0};cout<<"Enter your success of the three times 40 meters running:\n";cin >> ad[0]>>ad[1]>>ad[2];cout<<"success1:"<<ad[0]<<endl;cout<<"success2:"<<ad[1]<<endl;cout<<"success3:"<<ad[2]<<endl;ad[3]=(ad[0]+ad[1]+ad[2])/3;cout<<"average:"<<ad[3]<<endl;return 0;}第五章循环和关系表达式#include <iostream>int main(){using namespace std;cout<<"Please enter two integers: ";int num1,num2;cin>>num1>>num2;int sum=0;for(int temp=num1;temp<=num2;++temp)//or temp++sum+=temp;cout<<"The sum from "<<num1<<" to "<<num2<<" is "<<sum<<endl;return 0;}#include <iostream>#include<array>int main(){using namespace std;array<long double,101>ad={0};ad[1]=ad[0]=1L;for(int i=2;i<101;i++)ad[i]=i*ad[i-1];for(int i=0;i<101;i++)cout<<i<<"! = "<<ad[i]<<endl;return 0;}#include <iostream>#include <array>using namespace std;int main(){array<long double, 101> multiply;multiply[0] = multiply[1] = 1LL;for (int i = 2; i <= 100; i++)multiply[i] = multiply[i-1]*i;cout << multiply[100];return 0;}#include <iostream>int main(){using namespace std;cout<<"Please enter an integer: ";int sum=0,num;while((cin>>num)&&num!=0){sum+=num;cout<<"So far, the sum is "<<sum<<endl;cout<<"Please enter an integer: ";}return 0;}#include <iostream>int main(){using namespace std;double sum1,sum2;sum1=sum2=0.0;int year=0;while(sum2<=sum1){++year;sum1+=10;sum2=(100+sum2)*0.05+sum2;}cout<<"经过"<<year<<"年后,Cleo 的投资价值才能超过Daphne 的投资价值。
注意:下面的勘误中,红色字体为修改后的文字,提请各位读者注意。
1.第6页,”1.6语言标准”中的第3行,将1987年修改为1978年。
2.第22页,”2. main()函数”中的第1行,int main (void)后面的分号(;)删除。
3.第24页,“5. 声明”的第10行,也就是一个变量、函数或其他实体的名称。
4.第27页,图2.3中,下划线应该只包含括号中的内容;第2段的第4行,而不是存储在源代码中的指令。
5.第30页,“2.5.4 打印多个值”的第4行,双引号后面的第1个变量。
6.第34页,“2.7.3 程序状态”第2段的第4行,要尽量忠实于代码来模拟。
7.第35页,“2.10本章小结”第2段的第1句,声明语句为变量指定变量名,并标识该变量中存储的数据类型;本页倒数第2行,即检查程序每执行一步后所有变量的值。
8.第37页,“2.12编程练习”中第1题,把你的名和姓打印在一行……把你的名和姓分别打印在两行……把你的名和姓打印在一行……把示例的内容换成你的名字。
9.第40页,第1行,用于把英磅常衡盎司转换为……10.第44页,“3.4 C语言基本数据类型”的第1句,本节将详细介绍C语言的基本属性类型……11.第46页,“5.八进制和十六进制”的第4句,十六进制数3的二进制数是0011,十六进制数5的二进制数是0101;“6.显示八进制和十六进制”的第1句,既可以使用也可以显示不同进制的数;将“回忆一下……程序在执行完毕后不会立即关闭执行窗口”放到一个括号里。
12.第47页,“2.使用多种整数类型的原因”第3句,过去的一台运行Windows 3.x的机器上。
13.第53页,图3.5下面的第4行“上面最后一个例子(printf(“Gramps sez, \”a \\ is a backslash.\”\n”);)”14.第56页,正文的第2行和第4行应该分别为printf(“me32= %“ “d” “\n”, me32); printf(“me32= %d\n”, me32);15.第61页,“无符号类型”的最后1句,相当于unsigned int(即两者之间添加一个空格)。
16.第62页,程序清单3.8中的第1行,将//* typesize.c--打印类型大小*/中的第一个斜杠删除。
17.第63页,“3.6参数和陷阱”第2行,printf(“Hello,pal.”)(即Hello,和pal.之间没有空格)。
18.第64页,程序清单3.10中的第1行,使用转义序列。
19.第75页,倒数第8行,何时使用圆括号取决于运算对象是类型还是特定量。
20.第82页,第11行,……格式字符串包含了两个待打印项number和pies对应的……21.第83页,表4.4中的“L”修饰符的含义介绍中,应该是示例:”%L f”、“%10.4L e”22.第84页,表4.5中的第1行,即,从字段的左侧开始打印该项(即,应该只保留一个项);在“0”标记的含义中,添加一行:示例:"%010d"和"%08.3f"。
23.第86页,第1段的第2行,……字段宽度是容纳待打印数字所需的……;倒数第4段中,根据%x打印出1f,根据%X打印出1F24.第87页,“4.4.4转换说明的意义”第2段,……读者认为原始值被替换成转换后的值。
25.第89页,“参数传递”第2行,把变量n1、n2、n3和n4的值传递给程序(即,保留一个顿号)。
26.第93页,第5行的2121.45的字体应该与第4行的42的字体保持一致;表4.6上面的最后一行,对于dou ble类型要使用1修饰符。
27.第94页,表中的第3行,把对应的数值存储为unsignedshort int类型;把“j”转换说明的示例放到“z”转换说明中;在“j”转换说明的含义中添加:示例:”%jd”、”%ju”。
28.第95页,“3.scanf( )的返回值”上面一段的倒数第3行,如果在格式字符串中把空格放到%c的前面。
29.第98页,倒数第2段,strlen()函数(声明在string.h头文件中)可用于……。
30.第100页,”4.8编程练习”中的第2题,将该题中的“名和姓”统一替换为“名字”;并执行以下操作;第3题,将a、b项中的“输入”替换为”The input is”,将“或”替换为“or”,将末尾的分号换成点(.)。
31.第105页,第8行,由于19.0不小于18.5,所以该条件为假。
32.第107页,程序清单5.3下面的第1行,首先把68赋给jane。
33.第111页,图5.3下面的第1行,如何让加法运算在除法运算之前执行。
34.第117页,程序清单5.11结束后的第4行,而pre_b是b递增之后的值。
35.第118页,倒数第2行,而不是(x*y)++。
36.第129页,程序清单5.15的第4行,//1小时的秒数。
37.第134页,“5.11编程练习”中的第4题,168.7 cm = 5 feet, 6.4 inches38.第143页,正文第2段,假设你想跳过输入到达第1个既不是空白字符也不是数字的位置39.第148页,倒数第3行,高优先级组:< <= > >=(即在<和<=之间有空格,在>和>=之间有空格)40.第153页,第7行的“15”与下一行的“28”左对齐。
41.第161页,“小结:do while语句”中的倒数第4行,在expression为假或0之前(注意要用斜体)42.第167页,程序清单6.20的名字应该是power.c程序(即删除一个w)43.第170页,“6.15复习题”第1题,后5行中使用的是前一行生成的quack的值。
44.第175页,第10题的第3句话,用户输入的上限整数等于或小于下限整数为止。
45.第178页,中间部分的文字中,if语句指示几岁安及,如果刚读取的值(t emperature)小于0。
46.第185页,正文第2段,特别要注意的是,如果kwh大于360;中间代码之后的第1句,也就是说,该程序由一个if else语句组成(即,if和else之间要有一个空格)47.第187页,正文倒数第2段,倒数第3行,2和72、3和48、4和36。
48.第196页,代码中第2行,达到单词的末尾。
49.第212页,复习题的第4题,下列各表达式的值是多少。
50.第215页,第2题的第2句话,每行打印8个“字符-ASCII码”组合;第7题的a项中,10.00美元/小时。
51.第222页,“8.4重定向和文件”的第2句话,输入设备(我们假设)是键盘;“8.4.1UNIX、Linux和DO S重定向”的上面一段,重定向的一个主要问题是它与操作系统有关;苹果OSX运行在UNIX上,故可用Terminal应用程序来使用UNIX命令行模式。
52.第224页,“3.组合重定向”中的第2、4、6行中,应该是分别是./echo_eof < mywords > savewords、./echo_eof > savewords < mywords、./echo_eof < mywords > mywords….;第13行应该是./echo_eof<words;第16、17、18、19行的多买中,均在最前面添加./53.第225页,“小结:如何重定向输入和输出”中的4行代码中,均在前面添加./54.第227页,正文中间,该程序还是会把f视为n(即这里将“被”删除)。
55.第245页,倒数第6行中,程序中starbar( )和main()的定义形式相同。
56.第247页,“9.1.3 函数参数”中第2段最后1行,因此,可以调用show_n_char(‘ ‘, 12)(即两个单引号之间是一个空格)57.第260页,第19行,因此,n乘以n-1的阶乘就得到n的阶乘。
58.第268页,程序清单9.13上面的一行,在interchange()中使用u和v。
59.第272页,倒数第7行,让interchange()访问这两个变量。
60.第273页,“变量:名称、地址和值”中第3段第2行,使用变量名即可获得变量的数值。
61.第276页,“9.11编程练习”第6题,把最小值放入第一个变量;第10题,编写一个to_base_n()函数接受两个参数,且第2个参数在2~10范围内,然后以第2个参数……。
62.第285页,第11行,floatrain[5][12];(即float和rain之间有一个空格);图10.1上面的一句话,则使用rain[1][2];顺便将括号以及括号中的文字删除。
63.第289页,图10.3上面一段的第2行,这意味着加1后的地址是下一个元素的地址(即,将“把”删除)64.第290页,第1行,dates + 2 ==&date s[2]65.第295页,第3行,至于C语言,ar[i]和*(ar+i)这两个表达式都是等价的。
66.第305页,正文倒数第3段,第2行,指向一个内含3个int类型元素的数组;pa指向一个内含3个int类型元素的数组。
67.第307页,程序清单10.17上面的一段,这样的变量稍后能以同样的方式用作junk。
68.第316页,第6题,在a、b、c这3项的后面添加“的地址”69.第322页,上面第2行代码,I am a symbolic string constant.(即,将an换成a,将old-fashioned删除)70.第326页,“5.字符串数组”上面的一句,如果打算修改字符串,就不要用指针指向字符串字面量;“5.字符串数组”下面的一句,创建一个字符数组通常很方便(即将“如果”删除,将“会”换成通常)。
71.第332页,最后一段的第1句,fgets( )函数返回指向char的指针。
72.第336页,图11.3中“输入语句”栏,将这三个均修改为scanf(“%5s”,name);73.第348页,正文倒数第2段,并编写一个函数把输入的内容都转换成大写74.第356页,正文最后一段的第1句,程序清单11.28中的程序用s printf()把3个项75.第358页,第一行,该函数返回指向s字符串首次出现的c字符的指针76.第366页,正文第3段,如果字符串仅以整数开头,at oi()函数也能处理77.第370页,第5题的e项,如果用*pc--替换*--pc,会打印什么78.第371页,“11.13编程练习”第1题,从输入中获取n个字符(即将“下”删除)79.第372页,第8题,如果第2个字符串包含在第1个字符串中;第10题,该程序应该应用该函数读取每个输入的字符串,并显示处理后的结果;第11题,编写一个程序80.第374页,第2段,内含这些字符值的字符串字面量就是一个对象,由于字符串字面量中的每个字符都能被……81.第382页,“12.1.7外部链接的静态变量”第3行,放在所有函数的外面(即将其中一个“在”删除)82.第383页,正文最后一段第2行,外部变量Hocus对main()和magic()均不可见83.第391页,正文第1段,在这个文件中不要求写出该函数定义。