//习题10.11
inline void output_words(vector<string> &words)
{
for (auto i : words) {
cout << i << " ";
}
cout << endl;
}
bool isShorter(const string &s1, const string &s2)
{
return s1.size() < s2.size();
}
void elimDups(vector<string> &words)
{
output_words(words);
sort(words.begin(), words.end());//字典排序
output_words(words);
auto end_unique = unique(words.begin(), words.end());//删掉重复单词
output_words(words);
words.erase(end_unique, words.end());//去除末尾元素
output_words(words);
stable_sort(words.begin(), words.end(), isShorter);//大小排序,大小相同的维持原来的字典排序
output_words(words);
}
int main()
{
vector<string> words;
string word;
ifstream in("data");
while (in >> word)
words.push_back(word);
elimDups(words);
}
//习题10.13
inline void output_words(vector<string> &words)
{
for (auto i : words) {
cout << i << " ";
}
cout << endl;
}
inline bool five_or_more(const string &str1)
{
return (str1.size() > 5) || (str1.size() == 5);
}
int main()
{
vector<string> str;
string word;
ifstream in("data.txt");
if (!in) {
cerr << "未打开文件" << endl;
return -1;
}
while (in >> word)
str.push_back(word);
output_words(str);
auto iter = partition(str.begin(), str.end(), five_or_more);
output_words(str);
for (auto iter1 = str.begin(); iter1 != iter; iter1++)
cout << *iter1 << " ";
cout << endl;
}
C++Primer5th课后题10.11、10.13
最新推荐文章于 2018-11-03 21:34:24 发布