1074. Reversing Linked List (25)

/*注意:输入的节点通过排序后,可能会存在无效结点,即:除了从头结点走到-1的所有结点外,还有其他子链表,排除的方法:只要从头到尾走一遍记录下来,其它的都废弃。*/
#include<cstdio> //因为格式化输出,所以不用iostream 
#include<vector> //向量,相当于动态数组
#include<algorithm>  //c++中的reverse 
using namespace std;
#define MAX 100001

struct node{
	int addr;//自己的地址 
	int data;
	int next;//下一个地址 
};//分号不能少 
 
 

int main(){
	//freopen("in.txt","r",stdin); 
	int firstAddr,n,k;
	//cin>>firstAddr>>n>>k;
	scanf("%05d %d %d\n",&firstAddr,&n,&k);
	
	node list1[MAX];//node类型数组,存放接下来读的n个记录,节点.addr作为数组下标
	vector<node> list2;//node类型动态数组, 存放排序后的 n个记录 ,下标从0开始
	
	//读入 
	while(n--){
		node jiedian;//如果结构体里含指针,则应该node * jiedian=new node来声明 
		//cin>>jiedian.addr>>jiedian.data>>jiedian.next;//因为结构体里没有定义指针,所以用.而不会->指向节点内的属性 
		scanf("%05d %d %05d\n",&jiedian.addr,&jiedian.data,&jiedian.next);
		list1[jiedian.addr]=jiedian; 
	} 
	
	//排序 
	int addr=firstAddr;
	while(addr!=-1){
		list2.push_back(list1[addr]);
		addr=list1[addr].next;
	}
	
	//反转
	for(int i=0;i+k<=list2.size();i=i+k){//不能写成i+=k,否则通不过 
		reverse(list2.begin()+i,list2.begin()+i+k); //reverse是左闭右开函数
	} 
	/*反转法二:
	int length = list2.size();
	int round = length/k;
	for(int i = 1; i <= round; ++i){
		int start = (i-1)*k;
		int end = i*k;
		reverse(list2.begin() + start, list2.begin() + end);
	}*/ 
	 

	
	//输出 
	int j;
	for(j=0;j<list2.size()-1;j++){
		//cout<<list2[j].addr<<list2[j].data<<list2[j].next<<endl;//如00000必须用格式化输出5位0,所以要用printf
		printf("%05d %d %05d\n",list2[j].addr,list2[j].data,list2[j+1].addr); //注意最后一个不是 list2[j].next
	} 
	printf("%05d %d -1\n",list2[j].addr,list2[j].data); 

	return 0;
}

vector(向量): C++中的一种数据结构,确切的说是一个类.它相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间的目的.
用法:
  1.文件包含:  首先在程序开头处加上#include<vector>以包含所需要的类文件vector;  还有一定要加上using namespace std;
  2.变量声明:
    2.1 例:声明一个int向量以替代一维的数组:vector <int> a;(等于声明了一个int数组a[],大小没有指定,可以动态的向里面添加删除)。
    2.2 例:用vector代替二维数组.其实只要声明一个一维数组向量即可,而一个数组的名字其实代表的是它的首地址,所以只要声明一个地址的向量即可,即:vector <int *> a.同理想用向量代替三维数组也是一样,vector <int**>a;再往上面依此类推.

  3.具体的用法以及函数调用(其用法和数组一样)

	1.push_back   在数组的最后添加一个数据
	2.pop_back    去掉数组的最后一个数据 
	3.at          得到编号位置的数据
	4.begin       得到数组头的指针
	5.end         得到数组的最后一个单元+1的指针
	6.front       得到数组头的引用
	7.back        得到数组的最后一个单元的引用
	8.max_size    得到vector最大可以是多大
	9.capacity    当前vector分配的大小
	10.size       当前使用数据的大小
	11.resize     改变当前使用数据的大小,如果它比当前使用的大,者填充默认值
	12.reserve    改变当前vecotr所分配空间的大小
	13.erase      删除指针指向的数据项
	14.clear      清空当前的vector
	15.rbegin     将vector反转后的开始指针返回(其实就是原来的end-1)
	16.rend       将vector反转构的结束指针返回(其实就是原来的begin-1)
	17.empty      判断vector是否为空
	18.swap       与另一个vector交换数据
	19.insert     插入元素
部分函数详细解释
	c.push_back(elem)   在尾部加入一个数据。
	c.pop_back()        删除最后一个数据。

	c.begin()           返回指向容器第一个元素的迭代器
	c.end()             返回指向容器最后一个元素的迭代器	

	c.front()           传回第一个数据。

	c.size()            回容器中实际数据的个数。	 
	c.resize(num)       重新设置该容器的大小	 

	c.erase(pos)        删除pos位置的数据
	c.erase(beg,end)    删除[beg,end)区间的数据

	c.clear()           移除容器中所有数据。
	c.empty()           判断容器是否为空。

	c.insert(pos,elem)  在pos位置插入一个elem拷贝



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值