Essential C++ 第四章小结

2024-02-29 23:48
文章标签 c++ 小结 第四章 essential

本文主要是介绍Essential C++ 第四章小结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

随手画了一个图小结一下:


下面是根据书中的例子写的一些代码:

#include <iostream>
#include <vector>
#include "Triangulate_iterator.h"
using namespace std;static int arr[13] = {1,1,2,3,5,8,13,21,34,55,89,144,233};class Triangulate_iterator;class Triangulate {
public:typedef Triangulate_iterator iterator;/*申明Triangulate_iterator为Triangulate的友元,Triangulate_iterator里的函数都能对Triangulate的私有成员进行访问了*/friend class Triangulate_iterator;Triangulate();Triangulate(int length , int beg_pos);Triangulate(int length);Triangulate(const Triangulate&);Triangulate_iterator begin();Triangulate_iterator end();friend int operator* (const Triangulate_iterator &rhs);int length() const { return _length; }int beg_pos() const { return _beg_pos; }int length() { return _length; }int beg_pos() { return _beg_pos; }bool next(int &x) const;void next_reset() const;static bool is_elem( int );static int get_elem( int pos ) {return _elem[pos];}static void gen_elements( int length );static void gen_elems_to_value( int value );static void display( int length, int beg_pos, ostream &os = cout );static vector<int> _elem;private:string _name;int _length;int _beg_pos;mutable int _next;static const int _max_elems = 1024;};class Triangulate_iterator {
public:friend class Triangulate;Triangulate_iterator(int index) : _index(index-1) {}friend int operator* (const Triangulate_iterator &rhs);bool operator== ( const Triangulate_iterator& ) const;bool operator!= ( const Triangulate_iterator& ) const;int Triangulate_iterator::operator* (const Triangulate_iterator &rhs);Triangulate_iterator& operator++ ();Triangulate_iterator operator++ ( int );private:void check_integrity() const;  //检查 _index是否合理int _index;
};class iterator_overflow{};int operator* (const Triangulate_iterator &rhs) {rhs.check_integrity();return Triangulate::_elem[rhs._index];
}
inline bool Triangulate_iterator::operator == ( const Triangulate_iterator& rhs ) const {return this->_index == rhs._index;
}inline bool Triangulate_iterator::operator != ( const Triangulate_iterator& rhs ) const {return (! (*this == rhs ));
}
inline
int Triangulate_iterator::operator* (const Triangulate_iterator &rhs) {rhs.check_integrity();return Triangulate::_elem[_index];
}Triangulate_iterator& Triangulate_iterator::operator++ () {_index++;check_integrity();return *this;
}Triangulate_iterator Triangulate_iterator::operator++ ( int ) {Triangulate_iterator tem = *this;_index++;check_integrity();return tem;
}inline
void Triangulate_iterator::check_integrity() const {if ( _index >= Triangulate::_max_elems)throw iterator_overflow();if(_index >= Triangulate::_elem.size())Triangulate::gen_elements( _index + 1);
}Triangulate_iterator Triangulate::begin() {return Triangulate_iterator(_beg_pos);}Triangulate_iterator Triangulate::end() {return Triangulate_iterator(_beg_pos + _length);
}Triangulate::Triangulate(): _name("Triangulate"),_length(1),_beg_pos(1),_next(0) {}
Triangulate::Triangulate(int l, int b) : _name("Triangulate") {_length = l > 0 ? l : 1;_beg_pos = b > 0 ? b : 1;_next = _beg_pos-1;
}Triangulate::Triangulate(int l) : _name("Triangulate") {_length = l > 0 ? l : 1;_beg_pos = 1;_next = _beg_pos - 1;}Triangulate::Triangulate(const Triangulate &rhs) {_length = rhs._length;_beg_pos = rhs._beg_pos;_next = rhs._next;_name = rhs._name;
}bool Triangulate::next(int &elem) const {if(_next >= _length)return false;elem = _elem[_next];_next++;return true;
}void Triangulate::next_reset() const {_next = _beg_pos - 1;
}vector<int> Triangulate::_elem;int sum( const Triangulate &trian ) {if ( !trian.length())return 0;int sum = 0;int val = 0;trian.next_reset();while ( trian.next( val ))sum += val;return sum;
}bool Triangulate::is_elem( int value ) {if ( !_elem.size() || _elem[_elem.size()-1] < value)gen_elems_to_value(value);vector<int>::iterator found;vector<int>::iterator last = _elem.end();found = find(_elem.begin(), last, value);return found != last;
}void Triangulate::gen_elems_to_value( int value ) {int ix = _elem.size();if ( !ix ) {_elem.push_back(1);ix = 1;}if ( ix == 1) {_elem.push_back(1);ix = 2;}while ( _elem[ix-1] < value && ix < _max_elems) {_elem.push_back(_elem[ix-2] + _elem[ix-1]);ix++;}if( ix == _max_elems )cerr << " value too large " << value << " -- exceeds max size of "<< _max_elems << endl;}void Triangulate::gen_elements( int length ) {if ( length <= 0 || length > _max_elems )return;int ix = _elem.size();if ( length == 1 && ix < length ) {_elem.push_back(1);ix++;}if ( length == 2 && ix < length ) {if( ix == 0) {_elem.push_back(1);++ix;}_elem.push_back(1);++ix;}for (; ix < length; ix++ ) {_elem.push_back(_elem[ix-2] + _elem[ix-1]);}
}int main() {char ch;bool more = true;int i = Triangulate::_elem[0];while( more ) {cout << "Enter your value ";int value;cin >> value;cout << "the value " << (Triangulate::is_elem(value) ? "is " : "is not ")<< "the element of the Triangulate "<< " try more (y/n) " << endl;cin >> ch;if ( ch=='y' || ch=='Y' ) {more = true;} elsemore = false;}return 0;}


这篇关于Essential C++ 第四章小结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

Go之errors.New和fmt.Errorf 的区别小结

《Go之errors.New和fmt.Errorf的区别小结》本文主要介绍了Go之errors.New和fmt.Errorf的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考... 目录error的基本用法1. 获取错误信息2. 在条件判断中使用基本区别1.函数签名2.使用场景详细对