C++Primer第五版 9.3.4节练习
来源:互联网 发布:通讯网络与设备是什么 编辑:程序博客网 时间:2024/06/05 16:51
练习9.27:编写程序,查找并删除forward_list<int>
中的奇数元素。
答: 见练习9.27.cpp
练习9.28:编写程序,接受一个forward_list<string>
和 两个string共三个参数。函数应在链表中查找第一个string,并将第二个string插入到紧接着第一个string之后的位置。若第一个string未在链表中,则将第二个string插入到链表末尾。
答:见练习9.28.cpp
练习9.27
/**练习9.27*2015/8/2*问题描述:练习9.27:编写程序,查找并删除forward_list<int>中的奇数元素。*功能:forward_list的使用 *作者:Nick Feng *邮箱:nickgreen23@163.com * */#include <iostream>#include <string>#include <vector>#include <list>#include <forward_list>using namespace std;int main(){ forward_list<int> flst = {1,2,3,4,5,6,7,8,9}; auto prev = flst.before_begin(); auto curr = flst.begin(); while(curr != flst.end()) { if(*curr % 2) curr = flst.erase_after(prev); else { prev = curr; ++curr; } } for(auto it = flst.begin(); it != flst.end(); ++it) cout << *it << " "; cout << endl; return 0;}
练习9.28
/**练习9.28*2015/6/15*问题描述:练习9.28:编写程序,接受一个forward_list<string> 和 两个string共三个参数。函数应在链表中查找第一个string,并将第二个string插入到紧接着第一个string之后的位置。若第一个string未在链表中,则将第二个string插入到链表末尾。*说明:forward_list末尾元素,需要遍历得到,不能直接取得,另外注意,引用类型,和普通函数的区别,值的变化 *编写了三个函数,*take_last_value(),取到尾末迭代器, 返回尾末迭代器*look_value();//如果有这个string存在,返回那个位置的迭代器,否则,返回尾末迭代器*complace();//题目要求的函数,如果直接在这里面写循环,会造成,假如找到了匹配的string,循环还是会往后遍历,在尾末加string2,因此,需要借助look_value的帮助进行定位 *作者:Nick Feng *邮箱:nickgreen23@163.com * */#include <iostream>#include <forward_list>#include <string>using namespace std;forward_list<string>::iterator take_last_value(forward_list<string> &flst) //小函数,取得尾末迭代器,注意引用 { forward_list<string>::iterator curr = flst.begin(); forward_list<string>::iterator it = flst.begin(); while(1) { curr = it++;//it++和++it是有区别的 if(it == flst.end()) break; } return curr;}forward_list<string>::iterator look_value(forward_list<string> &flst,string str)//小函数,找准是否有str的迭代器,如果有,返回找到的迭代器,没有,返回尾末迭代器 { forward_list<string>::iterator it = flst.begin(); while(it != flst.end()) { if(*it == str) //找到了,退出循环 { return it; break; } else ++it; } return take_last_value(flst); //其他情况,返回尾末迭代器 }void complace(forward_list<string> &flst, string str1, string str2) //题目要求的函数 { forward_list<string>::iterator it; it = look_value(flst,str1); //调用第二个函数 flst.insert_after(it,str2);//相应位置插入 }void print(forward_list<string> flst){ for(auto it = flst.begin(); it != flst.end();++it) cout << *it << " "; cout << endl; } int main(){ forward_list<string> flst = {"This","is","a","test!"}; complace(flst,"a","good"); print(flst); complace(flst,"f","!!"); //因为flst是被引用的,因此,这里的flst是上面处理后的flst print(flst); return 0; }
0 0
- C++Primer第五版 9.3.4节练习
- C++Primer 第五版 1.1节练习
- C++Primer第五版 1.3节练习
- C++Primer第五版 1.6节练习
- C++Primer第五版 2.4节练习
- C++Primer第五版 3.1节练习
- C++Primer第五版 4.2节练习
- C++Primer第五版 4.3节练习
- C++Primer第五版 4.4节练习
- C++Primer第五版 4.6节练习
- C++Primer第五版 4.7节练习
- C++Primer第五版 4.8节练习
- C++Primer第五版 4.9节练习
- C++Primer第五版 4.5节练习
- C++Primer第五版 5.1节练习
- C++Primer第五版 5.2节练习
- C++Primer第五版 6.1节练习
- C++Primer第五版 6.4节练习
- 重新认识存储过程
- cocos2d-x 3.x C++和Lua通信方式:Lua堆栈正数索引和负数索引的关系和用法
- hdu 5444 Elven Postman
- selenium-webdriver(python) (十五) -- 鼠标事件
- android添加wifi热点管理黑白名单
- C++Primer第五版 9.3.4节练习
- WebCollector 网页正文提取算法(ContentExtractor)
- Z-Stack协议中事件和消息分析
- Java 完全数
- selenium-webdriver(python) (十六) --unittest 框架
- Java的poi技术读取和导入Excel简单实例
- 一段代码卡死安卓QQ 卡到手机QQ无响应
- [python] 0x3 Python Tutorial: Fuzzer
- linux命令大全