在C++中list作为双向链表,在数据的插入中相对于vector简直是太好用了。
在list中向头尾插入数据或者删除数据的操作:
list.push_back(); //在容器末尾插入一个元素
list.pop_back(); //删除容器末尾的最后一个元素
list.push_front(); //在容器开头插入一个元素
list.pop_front(); //删除容器开头的第一个元素
list.front(); //返回链表的第一个元素
list.back(); //返回链表的最后一个元素
迭代器
list.begin(); //返回容器的第一个元素
list.end(); //返回容器最后一个元素
题目:输出二维数组中相邻的数字
// list实现数组连续.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <iostream>
#include <vector>
#include <list>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
int ini[][2] = { { 3, 4 }, { 7, 3 }, { 4, 6 }, { 6, 8 }, {1,7} };
list<int>l;
l.push_back(ini[0][0]);
l.push_back(ini[0][1]);
for (int i = 1; i < 5; i++)
{
if (l.front() == ini[i][1])//链表第一个数字等于数组第二列,将其所在行的第一个数字插入链表
{
l.push_front(ini[i][0]);
}
if (l.back() == ini[i][0])//链表末的数字等于数组第一列,将其所在行的第二个数字插入链表
{
l.push_back(ini[i][1]);
}
}
//print
for (list<int>::iterator it = l.begin(); it != l.end(); it++)
{
cout << *it;
}
return 0;
}