STL容器
啦啦啦,今天听啦高年级学长讲的STL容器啦,发现有好多东西还是有必要记载的,毕竟学长是身经百战的,他在参加各种比赛的时候积累的经验可不是一天两天就能学来的,那个可是炒鸡有价值的啊,啊啊啊啊啊
#include<iomanip>
#include<iostream>
#include<string.h>
using namespace std;
int main()
{
char a[], b[];
cin >> b;
strcpy(a, b);
cout << a << ":::" << b << endl;
strcat(a, b);
cout << a << endl;
char *q = strchr(a, 'a');///在这里该函数返回'a'出现的首地址,当找不到‘a’时返回NULL,具体看下图
cout << q << endl;
cout << strcmp(a, b) << ":::" << strcmp(b, a) << ":::" << strcmp(a,a) <<endl;
int l = strlen(a);
cout << l << endl;
}
在网上查到过,在好多论文中提到过memset中存在某种机制,将会使得它比for的循环赋值快一些
全排列函数next_permutation();用于求算字符串或者数组的全排列,
**但是尤为要注意的一点是该函数只会返回从给定的字符串或者数组字典序之后的序列,也就是说当我们想要求出全排列的时候我们应该先为数组或者字符串排序
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
string s="bca";
sort(s.begin(),s.end());
cout<<s<<endl;
while(next_permutation(s.begin(),s.end()))
{
cout<<s<<endl;
}
}
排序时的结果

未排序时的结果

没有第8行时的结果

排序int型数组
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
int a[]= {,,};
sort(a,a+);
cout<<a[]<<" "<<a[]<<" "<<a[]<<endl;
while(next_permutation(a,a+))
{
cout<<a[]<<" "<<a[]<<" "<<a[]<<endl;
}
}
在比赛中积累的经验得知,这个求全排列的函数比我们自己写的用dfs求的全排列要快
对于平时的时间要求较高的题目,我们会用到二分查找,但是对于边界我们却总是不能正确找到,这里有一个二分查找的函数,它的时间复杂度时log级别的
lower_bound(a,a+n,b);求该函数返回在a数组中b首次出现的地址
upper_bound(a,a+n,b);求该函数返回在a数组中b末次出现的地址
**要注意的一点是对于a数组在它传递给该函数的时候要严格遵守升序排列才能找到,因为这个函数时严格遵守二分查找的法则,否则就会报错
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
int a[]={,,,,};
cout << lower_bound(a,a+,)-a << endl;
cout << upper_bound(a,a+,)-a << endl;
}
对于string类型用sort排序方法
string s="abc";
sort(s.begin(),s.end());
STL容器的更多相关文章
- c++ stl容器set成员函数介绍及set集合插入,遍历等用法举例
c++ stl集合set介绍 c++ stl集合(Set)是一种包含已排序对象的关联容器.set/multiset会根据待定的排序准则,自动将元素排序.两者不同在于前者不允许元素重复,而后者允许. 1 ...
- STL容器删除元素的陷阱
今天看Scott Meyers大师的stl的用法,看到了我前段时间犯的一个错误,发现我写的代码和他提到错误代码几乎一模一样,有关stl容器删除元素的问题,错误的代码如下:std::vector< ...
- 【转】c++中Vector等STL容器的自定义排序
如果要自己定义STL容器的元素类最好满足STL容器对元素的要求 必须要求: 1.Copy构造函数 2.赋值=操作符 3.能够销毁对象的析构函数 另外: 1. ...
- GDB打印STL容器内容
GDB调试不能打印stl容器内容,下载此文件,将之保存为~/.gdbinit就可以使用打印命令了. 打印list用plist命令,打印vector用pvector,依此类推. (gdb) pvecto ...
- STL容器迭代器失效分析
连续内存序列容器(vector, string, deque) 对于连续内存序列STL容器,例如vector,string,deque,删除当前iterator会使得后面所有的iterator都失效, ...
- STL容器的适用情况
转自http://hsw625728.blog.163.com/blog/static/3957072820091116114655254/ ly; mso-default-props:yes; m ...
- STL容器的遍历删除
STL容器的遍历删除 今天在对截包程序的HashTable中加入计时机制时,碰到这个问题.对hash_map中的每个项加入时间后,用查询函数遍历hash_map,以删除掉那些在表存留时间比某个阈值长的 ...
- STL容器与配接器
STL容器包括顺序容器.关联容器.无序关联容器 STL配接器包括容器配接器.函数配接器 顺序容器: vector 行为类似于数组,但可以根据要求 ...
- STL容器的本质
http://blog.sina.com.cn/s/blog_4d3a41f40100eof0.html 最近在学习unordered_map里面的散列函数和相等函数怎么写.学习过程中看到了一个好帖子 ...
随机推荐
- 关于判断checkbox选中问题
attr和prop的区别: 因为DOM节点属性可以理解为静态的,当页面渲染完,checked属性就确定了,就是checked.而HTML元素属性是动态的,随时可以改变,而且对于checked这个属性, ...
- JavaScript:修改作用域外变量
今天在看JavaScript学习指南的时候做的课后习题,也因此详细的对函数的传入参数进行比较深入的研究. 题目如下: 函数如何才能修改其作用域之外的变量?编写一个函数,由1~5的数字组成的数组作为参数 ...
- ZTOOLS HTTP®EXTEST&JSONS 工具包
下载地址:点击下载
- Android AsyncTask 简单用法
简介 AsyncTask 是一个轻量级的异步处理类.使用是需继承自该类.可以方便的执行异步任务并且在将进度显示在UI上. 注意事项 AsyncTask只适合处理轻量级的任务即耗时几秒或者几十秒的任务. ...
- mysql 基础列题
1:emp表中查询公司总共有几个部门注意,会查询出来大量重复的,使用函数distinctselect distinct job from scott.emp; 2:查询公司工资在1000-3000之间 ...
- C++引用详解
引用的概念 引用:就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样. 引用的声明方法:类型标识符 &引用名=目标变量名: 如下:定义引用ra,它是变量a的引用,即别名. i ...
- grid安装
在cs6.5,cs7.2上安装grid11.2.0.1 和database11.2.0.1还是有问题 1.i386与i686的问题 2.cs7.2中的semmni内核参数问题 已经设置了kernel. ...
- python-print
%s,%d就是占位符.还有%r 只是说明这样的对应:%s-->str();%r-->repr(),什么意思呢?就是说%s调用的是str()函数把对象转化为str类型,而%r是调用了repr ...
- 富文本编辑器防止xss注入javascript版
富文本编辑器:ueditor 其实富文本编辑器已经有防止xss注入功能,但是你服务端程序在接收的时候在做一次转义,否则有可能然后前端验证直接提交数据导致被xss攻击. 为了节省后端程序开销则在前端 显 ...
- WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED解决方法
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ WARNING: REMOTE HOST IDENTIFICATION ...