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

相关文章

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

Java强制转化示例代码详解

《Java强制转化示例代码详解》:本文主要介绍Java编程语言中的类型转换,包括基本类型之间的强制类型转换和引用类型的强制类型转换,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录引入基本类型强制转换1.数字之间2.数字字符之间引入引用类型的强制转换总结引入在Java编程语言中,类型转换(无论

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制