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

相关文章

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.使用场景详细对

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

MySQL慢查询工具的使用小结

《MySQL慢查询工具的使用小结》使用MySQL的慢查询工具可以帮助开发者识别和优化性能不佳的SQL查询,本文就来介绍一下MySQL的慢查询工具,具有一定的参考价值,感兴趣的可以了解一下... 目录一、启用慢查询日志1.1 编辑mysql配置文件1.2 重启MySQL服务二、配置动态参数(可选)三、分析慢查

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用