编写一个C++程序:

vector初始化两种方法:

vector<int>elem_seq(seq_size);

elem_seq[0]=1

elem_seq[1]=2;

另一种方法则是利用一个已初始化的array作为vector的初值

int elem_vals[seq_size]={元素}

vector<int>elem_seq(elem_vals,elem_vals+seq_size};

vector<int > m_vtmp;
m_vtmp.assign(arr,arr+5);

rand()和srand()都是标准程序库提供的所谓伪随机数产生器.srand()的参数是所谓随机数产生器种子(seed)。要知道,每次调用rand(),都回返回一个介于0和“int 所能表示的最大整数”间的一个整数,现在,将随机数产生器的种子(seed)设为5,我们就可以将rand()的返回值限制在0和5之间这两个函数的声明式位于cstdlib头文件中

欲对文件进行读写操作,首先得含入fstream头文件

#include<fstream>

为了开启一个可供输出的文件,我们顶一个一个ofstream(供输出用的file stream)对象,并将文件名传入:

ofstream outfile("seq_data.txt")如果指定文件不存在,便会有一个文件被产生出来并开启作为输出只用,如果存在,这个文件被开启作为输出之用,而文件原来的数据会被丢弃.

如果不想丢弃数据,提供第二个参数ofstream outfile("seq_data.txt",ios_base::app);

if(!outfile)检验是否开启成功,cerr代表标准错误输出设备,cerr的输出结果没有缓冲,他会立即显示到用户终端机

else outfile<<"";

同理可供读取的文件,我们可顶一个一个ifstream(input file stream)对象,并将文件名传入,如果文件未能开启成功

if(!infile)

else while(infile>>name)

如果想同时读写一个文件,我们定义一个fstream对象,为了以追加模式开启,我们传入第二参数值

fstream iofile("seq_data.txt",ios_base::in|ios_base::app);

面向过程的编程风格

可以这样,更高的可见度void display(const vector<int>&,ostream&=cout);

void display(const vector<int>&vec,ostream &os)

{}

至于函数定义处,并没有指定参数的默认值

将函数指定为inline,体积小,常被调用,所从事的计算并不复杂

inline函数的定义常常被置于头文件中,由于编译器必须在它被调用的时候加以展开,所以这个时候起定义必须有效地

template<typename elemType>

function template 同时也可以是重载函数.

关键字enum之后是一个可有可无的识别名称,定义处枚举类型,大括号里头是以逗号为区隔的列表,表中每个项目成为枚举成员

默认情况下,第一个枚举成员的值为0,接下来的每个枚举成员都比前面一个多1

const object就和inline函数一样,是“一次定义规则”下的例外,const object的定义只要一出文件之外便不可见,这意味着我们可以在多个程序代码文件中加以定义,不会导致任何错误,

::表示此iterator乃是位于string vector定义式内的嵌套型别

使用序列式容器

序列式容器用来维护一组排列有序,型别相同的元素,其中有第一,第二,。。。。以此类推,乃至最后一个元素

vector和list是两个最主要的序列式容器,deque(双向队列)

所有容器类的共同操作

1,equality(==)和(inequality)(!=)运算符,返回true或false

2,assignment(=)运算符,将某个容器复制给另一个容器

3,empty()会在容器无任何元素时返回true,否则返回false

4,size()传用容器内当前含有的元素数目

5,clear()清除所有元素

list不支持偏移算法

使用泛型算法

1,find

2,binary_search   maxelement,copy

3,count

4,search

find_if

function objects

#include<functional>

sort(vec.begin(),vec.end(),greater<int>());

binary_search(vec.begin(),vec.end,elem,greater<int>());

另外数种稍加变化的方式显示Fibonacci数列,每个元素自身相加,和自身相乘,被加到对应的pell数列。。。。等等,做法之一是使用泛型算法transform()并搭配plus<int>和multiplies<int>

adapter(配接器)

标准程序库提供两个binder adapter(绑定配接器);bind1st会将指定值绑定至第一操作数,bind2nd则将指定值绑定之第二操作数。

(关于bind2nd的介绍http://blog.csdn.net/simahao/article/details/405455)

另一种adaptor是所谓的negator,它会逆转function object的真伪值,not1可逆转unary function object的真伪值,not2可逆转binary

function object的真伪值,

find_if的用法http://blog.csdn.net/hj490134273/article/details/6051080

欲查询map内是否存在某个key,有三种方法

1.最直观的做法就是吧key当索引使用

缺点是,如果我们用来索引的那个key并不存在map内,则呢个key会自动被加入map,而其value将是0

2.map查询法是利用map的find()函数,如果key已置于其中,find()会返回一个iterator,指向keyvalue形成一个pair,反之则返回end()

3.map查询发是利用map的count()函数,count()会返回某特定项目在map内的个数:

3.8使用set

set<string>

对于任何key值,set只能存储一份,如果要存储多份相同的key值,必须使用multiset

默认情况下,set元素,依据其所属型别的less-than,运算符进行排列

set<int>iset(vec.begin(),vec.end())

essential c++ 随笔的更多相关文章

  1. Essential C#读书笔记

    Essential C#读书笔记 这是一个多变的时代,一次又一次的浪潮将不同的人推上了巅峰.新的人想搭上这一波,同时老的人也不想死在沙滩上.这些年新的浪潮又一次推开,历史不停地重复上演,那便是移动互联 ...

  2. AI人工智能系列随笔

    初探 AI人工智能系列随笔:syntaxnet 初探(1)

  3. 【置顶】CoreCLR系列随笔

    CoreCLR配置系列 在Windows上编译和调试CoreCLR GC探索系列 C++随笔:.NET CoreCLR之GC探索(1) C++随笔:.NET CoreCLR之GC探索(2) C++随笔 ...

  4. C++随笔:.NET CoreCLR之GC探索(4)

    今天继续来 带大家讲解CoreCLR之GC,首先我们继续看这个GCSample,这篇文章是上一篇文章的继续,如果有不清楚的,还请翻到我写的上一篇随笔.下面我们继续: // Initialize fre ...

  5. C++随笔:从Hello World 探秘CoreCLR的内部(1)

    紧接着上次的问题,上次的问题其实很简单,就是HelloWorld.exe运行失败,而本文的目的,就是成功调试HelloWorld这个控制台应用程序. 通过我的寻找,其实是一个名为TryRun的文件出了 ...

  6. ASP.NET MVC 系列随笔汇总[未完待续……]

    ASP.NET MVC 系列随笔汇总[未完待续……] 为了方便大家浏览所以整理一下,有的系列篇幅中不是很全面以后会慢慢的补全的. 学前篇之: ASP.NET MVC学前篇之扩展方法.链式编程 ASP. ...

  7. 使用Beautiful Soup编写一个爬虫 系列随笔汇总

    这几篇博文只是为了记录学习Beautiful Soup的过程,不仅方便自己以后查看,也许能帮到同样在学习这个技术的朋友.通过学习Beautiful Soup基础知识 完成了一个简单的爬虫服务:从all ...

  8. 利用Python进行数据分析 基础系列随笔汇总

    一共 15 篇随笔,主要是为了记录数据分析过程中的一些小 demo,分享给其他需要的网友,更为了方便以后自己查看,15 篇随笔,每篇内容基本都是以一句说明加一段代码的方式, 保持简单小巧,看起来也清晰 ...

  9. 《高性能javascript》 领悟随笔之-------DOM编程篇(二)

    <高性能javascript> 领悟随笔之-------DOM编程篇二 序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整 ...

随机推荐

  1. java+spring 执行器

    A 通过MethodInvokingJobDetailFactoryBean类实现 spring配置文件里增加执行器配置 <bean id="ammoDue" class=& ...

  2. 用”人话”解释CNN —— 对单个特征图进行视觉化

    转载自:http://nooverfit.com/wp/pycon-2016-tensorflow-研讨会总结-tensorflow-手把手入门-用人话解释cnn 首先什么是CNN? 其实, 用”人话 ...

  3. gcc, g++ - GNU 工程的 C 和 C++ 编译器 (egcs-1.1.2)

    总览 (SYNOPSIS) gcc [ option | filename ]... g++ [ option | filename ]... 警告 (WARNING) 本手册页 内容 摘自 GNU ...

  4. python基础一 day14 复习

    迭代器和生成器迭代器:双下方法 : 很少直接调用的方法.一般情况下,是通过其他语法触发的可迭代的 —— 可迭代协议 含有__iter__的方法('__iter__' in dir(数据))可迭代的一定 ...

  5. Repbase library|divergence rate|self-sequence alignment|genomic rearrangement|cutoffs|breakpoint

    (Panda, dog and human repeat comparison):与其他动物比较重复序列 我们使用Repbase 库(重复序列库)+已知的转录原件序列+识别软件,评估出转录原件占比,并 ...

  6. 洛谷 P1019 单词接龙 (DFS)

    题目传送门 当时一看到这题,蒟蒻的我还以为是DP,结果发现标签是搜索-- 这道题的难点在于思路和预处理,真正的搜索实现起来并不难.我们可以用一个贪心的思路,开一个dic数组记录每个单词的最小重复部分, ...

  7. Bootstrap历练实例:大的按钮

    <!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content=& ...

  8. ios之自定义UISwitch

    系统自带的UISwitch是这样的: 既不能写字,也不能改颜色,于是在网上找到了这么一个自定义的Switch按钮,具体出处找不见了.记录一下,怕以后找不见了. 先看下效果图: 按钮的样式很多,可以文字 ...

  9. [LUOGU] P1387 最大正方形

    题目描述 在一个n*m的只包含0和1的矩阵里找出一个不包含0的最大正方形,输出边长. 输入输出格式 输入格式: 输入文件第一行为两个整数n,m(1<=n,m<=100),接下来n行,每行m ...

  10. TUN/TAP/VETH

    TUN/TAP虚拟网络设备为用户空间程序提供了网络数据包的发送和接收能力.他既可以当做点对点设备(TUN),也可以当做以太网设备(TAP). TUN/TAP虚拟网络设备的原理: 在Linux内核中添加 ...