C++代码编程学习:泛型编程风格——iterator学习一(Essential C++ 第三章)

2024-06-16 22:36

本文主要是介绍C++代码编程学习:泛型编程风格——iterator学习一(Essential C++ 第三章),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C++中泛型编程风格——iterator学习,挺有难度,概念很抽象,这里主要把一些知识点和习题给过一遍!

一、前言

  C++中泛型编程风格——iterator学习(Essential C++ 第三章)。

二、例题

  • P218 练习 3.1
      写一个读取文本文件的程序,将文件中的每个单字存人 map。map 的 key便是刚才所说的单字,map 的 value 则是该单字在文本文件中的出现次数。再定义一份由“排除字眼”组成的 set,其中包含诸如 a、an、or、the、and 和 but 之类的单字。将某单字放入 map 之前,先确定该单字并不在“排除字集”中。一旦文本文件读取完毕,请显示一份单字清单,并显示各单字的出现次数。你甚至可以再加以扩展,在显示单字之前,允许用户查询某个单字是否出现于文本文件中。

  • 简单分析一下,四个函数:(1)筛选功能:再定义一份由“排除字眼”组成的 set,其中包含诸如 a、an、or、the、and 和 but 之类的单字;(2)计数功能:map 的 key便是刚才所说的单字,map 的 value 则是该单字在文本文件中的出现次数;(3)查询功能:在显示单字之前,允许用户查询某个单字是否出现于文本文件中;(4)显示功能:显示一份单字清单,并显示各单字的出现次数。

#include<map>
#include<set>
#include<string>
#include<iostream>
#include<fstream>
using namespace std;void init_exclusion_set(set<string>&);
void process_file(map<string, int>&, const set<string>&, ifstream&);
void user_query(const map<string, int>&);
void display_word(const  map<string, int>&, ofstream&);int main() 
{ifstream ifile("C:\\Users\\13660\\Desktop\\column.txt");ofstream ofile("C:\\Users\\13660\\Desktop\\column.map");if (!ifile || !ofile){cerr << "Unable to open file\n";return -1;}set<string> exclude_set;init_exclusion_set(exclude_set);map<string, int> word_count;process_file(word_count,exclude_set,ifile);user_query(word_count);display_word(word_count, ofile);
}void init_exclusion_set(set<string> &exs)
{static string excluded_words[6] = {"a","ab","or","the","and","but"};exs.insert(excluded_words, excluded_words+6);
}void process_file(map<string, int> &word_count, const set<string> &exclude_set, ifstream &ifile)
{string word;while (ifile >> word){if (exclude_set.count(word)){continue;}word_count[word]++;}
}void user_query(const map<string, int> &word_map)
{string searche_word;cout << "Please input a word to search: Q or q to quit";cin >> searche_word;while (searche_word.size() && searche_word != "q" && searche_word != "Q"){map<string, int>::const_iterator it;if ((it = word_map.find(searche_word)) != word_map.end()){cout << it->first << it->second << "\n";}else{cout << "Can't find.";}cout << "\n Another search? (q or Q to quit)";cin >> searche_word;}
}void display_word(const  map<string, int> &word_map, ofstream &os)
{map<string, int>::const_iterator iter = word_map.begin(), end_it = word_map.end();while (iter != end_it){os << iter->first << "(" << iter->second << ")" << endl;++iter;}os << endl;
}
  • 还是需要自己敲一敲代码才行。使用不熟悉。

在这里插入图片描述
在这里插入图片描述

-P220 练习 3.2
  读取文本文件内容–和练习 3.1一样–并将内容储存于 vector。以字符串长度为依据,对 vector排序。定义一个 function object 并传给 sort();这- function object接受两个字符串,当第一字符串的长度小于第二字符串的长度时,就返回true。最后,打印排序后的 vector 内容。


class LessThan {
public:bool operator() (const string &s1, const string &s2){return s1.size() < s2.size();}
};// sort(vec.begin(),vec.end(),LessThan());template <typename elemType>
void display_vector(const vector<elemType>& vec, ostream& os = cout, int len = 8)
{vector<elemType>::const_iterator iter = vec.begin(), end_iter = vec.end();int elem_cnt = 1;while (iter != end_iter){os << *iter++ << (!(elem_cnt++ % len) ? '\n' : ' ');}os << endl;
}

代码是在 visual studio 中编写的,该软件还是比较好用的,我安装的是2022专业版;

共勉!

这篇关于C++代码编程学习:泛型编程风格——iterator学习一(Essential C++ 第三章)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1067745

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型