【远古黑历史】List链表及其功能
前言
我知道有学校是禁用STL的,
但STL是真的香,加个蛋,嗯,好吃
所以,本人希望有更多OIer能使用STL,减少工作量!
初见STL
首先,什么是STL?
STL,全称 Standard Template Library,也就是标准模板库,
它是在惠普实验室开发出来的,它主要出现到C++中,
STL的代码从广义上讲分为三类:algorithm(算法)、container(容器)和iterator(迭代器),
然后,STL需要调用一个头文件
1 #include<algorithm>
没错,就是算法
当然,万能头是可以包含所有STL的头文件的
好的,回归正题
链表
什么是链表?
链表是一种上非连续、非顺序的存储结构
链表可以在中间、前面、后面插入
特点是——乱
那为什么?
让我们解释下
假设数组里面有编号1、2、4、5、6
在数组是这样的

链表中,是这样标记的

看,记录了下一项
现在看看插入时
假设要在2~4间插入3
数组需要大量的交换
首先放进末尾

然后......



十分繁琐
链表却很简单

不懂了吧?
还记得吗,链表记录了下一项,
所以,虽然链表数组是不符合我们期望的,
但通过记录下一项,我们可以实现方便快捷的插入
List
STL提供了好用的链表
定义List
需要头文件list
方法1:正规方式
list<类型> 链表名;
list<int> a;//定义一个整形链表,名为a
方法2:构造函数
这个方法我本来不知道的
list() //声明一个空列表; list(n) //声明一个front()有n个元素的列表,每个元素都是由其默认构造函数T()构造出来的 list(n,val) //声明一个由n个元素的列表,每个元素都是由其复制构造函数T(val)得来的 list(n,val) //声明一个和上面一样的列表 list(first,last)//声明一个列表,其元素的初始值来源于由区间所指定的序列中的元素
来自Donny_you神犇的《C++中list用法详解》
访问List
假设有一个链表a;
front和back可以返回元素
a.front();//获得链表的头部元素
a.back();//获得链表的尾部元素
begin和end可以返回地址
a.begin();//获得链表的头部地址
a.end();//获得链表的尾部地址
注意!地址和元素是不同的
但*a.begin()可以等价于a.front();
*a.end()可以等价于a.back();
那怎么输出链表呢?
需要一个迭代器iterator
还记得链表会记录下一项吗?
在C++的list里,下一项记录在地址中
比如有了第n项的地址*n,第n+1项的地址就为*n+1
这样,有了begin和end,用i表示当前地址,不断i++,就可以输出了
注意!虽然在vector中,结束可以是i>=a.end()\
但在list中,它是乱的,必须是i!=a.end()
存储i时,我们需要用iterator来不断迭代
iterator很重要,在接下来的vector也会介绍
格式怎么打?教你一招
for(int i=a.begin();i!=a.end();i++)
{
printf("%d\n",*i);
}
然后就报错了
在报错中寻找格式即可
for(list<int>::iterator i=a.begin();i!=a.end();i++)
{
printf("%d\n",*i);
}
放入元素
常用的两个函数
a.push_front(x)//将x加到最前面
a.push_back(x)//将x加到最后面
insert,功能强大
a.insert(i,x); //在i位置插入x
a.insert(i,y,x);//在i位置插入y个x
a.insert(i,b.begin(),b.end());//在i位置插入整个b链表
弹出元素
a.clear()//清空使用a的元素
a.resize(x)//将a改为只能容纳x个元素,其他弹出 a.pop_front()// 弹出第一个元素
a.pop_back() //弹出倒数第一个元素
其他函数
swap(a,b)//交换a和b链表
a.sort()//将a排序
a.unique()//将a去重
a.merge(b)//将ab合并,存在a里
a.empty()//判断是否为空
如果有遗漏,欢迎补充
例题
给出n个整数,每个数在long long范围内,把这些数升序排序后,去掉重复的,然后输出。
是不是很像明明的随机数?但数据在long long,桶排序不行了
list可以既简单又快速
因为有函数
#include<bits/stdc++.h>
using namespace std;
list<long long> a;
long long n,x;
int main()
{
scanf("%lld",&n);
for(int i=1;i<=n;i++)
{
scanf("%lld",&x);
a.push_front(x); }
a.sort();
a.unique();
for(list<long long>::iterator i=a.begin();i!=a.end();i++)
{
printf("%lld\n",*i);
}
}
那今天就到此为止了,喜欢就请关注我这个蒟蒻,谢谢!
如有错误,欢迎指出!
【远古黑历史】List链表及其功能的更多相关文章
- rlwrap: command not found和解决linux下sqlplus 提供浏览历史命令行的功能
rlwrap工具可以解决linux下sqlplus 提供浏览历史命令行的功能,和删除先前输入错误的字母等问题 1.安装 需要readline包 这个安装光盘就有 [root@asm RedHat]# ...
- Java 实现简答的单链表的功能
作者:林子木 博客网址:http://blog.csdn.net/wolinxuebin 參考网址:http://blog.csdn.net/sunsaigang/article/details/5 ...
- Windows Live Writer 历史Blog修改的功能
其实 WLW 有历史Blog修改的功能,我只是一直没有找到,就在打开“最近发布的日志”里面, 位于屏幕的右侧“打开”列表下. 最近发现记忆力越来越差了,BLOG看来是必须的了.
- python实现单链表及链表常用功能
单链表及增删实现 单链表高级功能实现:反序,找中间结点,检测环等 参考: https://github.com/wangzheng0822/algo
- c++单链表基本功能
head_LinkNode.h /*单链表类的头文件*/#include<assert.h>#include"compare.h"typedef int status; ...
- Java实现单向链表基本功能
一.前言 最近在回顾数据结构与算法,有部分的算法题用到了栈的思想,说起栈又不得不说链表了.数组和链表都是线性存储结构的基础,栈和队列都是线性存储结构的应用- 本文主要讲解单链表的基础知识点,做一个简单 ...
- terminal下历史命令自动完成功能history auto complete
CentOS下,有一个很智能的功能,就是只输入一条历史命令的前几个字母,再按PageUp和PageDown键,就可以在以此字母为前缀的历史命令中上下切换.这个功能非常实用,而且比CTRL+R使用起来更 ...
- python--自己实现的单链表常用功能
最近一个月,就耗在这上面吧. 很有收获的. # coding = utf-8 # 单向链表 class Node: def __init__(self, new_data): self.data = ...
- c++ 链表基础功能实现
#include<stack> struct ListNode { int m_nValue; ListNode* m_pNext; }; ListNode* CreateListNode ...
随机推荐
- 4.4 ROS节点名称重名
4.4 ROS节点名称重名 场景:ROS 中创建的节点是有名称的,C++初始化节点时通过API:ros::init(argc,argv,"xxxx");来定义节点名称,在Pytho ...
- python学习笔记(五)——静态方法、类方法、运算符重载
我们都知道类名是不能够直接调用类方法的.在C++中,把成员方法声明为 static 静态方法后可以通过类名调用.同样的在python中也可以通过定义静态方法的方式让类名直接调用. 静态方法 使用 @s ...
- 百度开放云 BOS Uploader
百度开放云 BOS Uploader bce-bos-uploader 是基于 bce-sdk-js 开发的一个 ui 组件,易用性更好.DEMO地址是:http://leeight.github.i ...
- 微信小程序要求HTTPS,如何选择SSL证书?
为了保护小程序应用安全,微信官方的需求文档要求,每个微信小程序必须事先设置一个通讯域名,并通过HTTPS请求进行网络通信,不满足条件的域名和协议无法请求.因此开发者应先准备好配置好HTTPS证书的域名 ...
- 利用Charles做代理测试电脑上写的H5页面
做H5页面的同学可能经常会遇到一个场景,就是电脑上调试好的页面怎么在手机上访问测试呢? 下面就介绍一种自己经常使用的方式,利用Charles代理软件来实现! 安装Charles 直接去官网下载对应的系 ...
- PAT B1081 检查密码
题目描述: 本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能.该网站要求用户设置的密码必须由不少于6个字符组成,并且只能有英文字母.数字和小数点 .,还必须既有字母也有数字. 输入格式: ...
- 【Android开发】【第三方SDK】 安卓版分词功能
功能介绍: 获取剪切板内容,进行分词: 点击分解后的词,填入输入框: 点击叉号将地址拼接起来返回主界面 用途: 增加用户的体验效果,可以直接在微信上复制地址,然后通过此功能确认地址. 附上git地址 ...
- EMS创建独立新用户并分配邮箱
创建新用户"王春海"并分配邮箱. 以Exchange管理员身份登录EMS控制台.在PowerShell命令行提示符下,键入如下命令: [PS] C:\Windows\system3 ...
- 解决vscode卡顿,CPU占用过高的问题
打开vscode之后,点击文件==>首选项==>设置 搜索设置 search.followSymlinks 然后将这个值改为false
- 不同标准下的C语言常量范围的默认类型的检测 (测试样例为C90与C99)
不同标准下的C语言常量范围的默认类型的检测 一.C90与C99标准下的不同常量范围的默认类型 C90标准下对不同常量范围默认类型的检测实现及运行结果: C99标准下对不同范围默认类型的检测实现 ...