ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

PAT A1133 Splitting A Linked List

2019-08-31 20:02:36  阅读:222  来源: 互联网

标签:tmp node PAT int Splitting ans A1133 data size


PAT A1133 Splitting A Linked List

在这里插入图片描述

Sample Input:

00100 9 10
23333 10 27777
00000 0 99999
00100 18 12309
68237 -6 23333
33218 -4 00000
48652 -2 -1
99999 5 68237
27777 11 48652
12309 7 33218

Sample Output:

33218 -4 68237
68237 -6 48652
48652 -2 12309
12309 7 00000
00000 0 99999
99999 5 23333
23333 10 00100
00100 18 27777
27777 11 -1
  • 心态崩:
    and all the values in [0, K] appear before all those greater than K.:误把这个条件理解成了下标属于[0,k]并且比K小的元素,实际上就是:以k为分界,0到k直接的数,排在比k大的数前面

  • 思路 1:

  1. 遍历链表,把所有节点用一个vector记录下来
  2. 对vector遍历三遍,分别筛选出符合3个条件的数:
    • 条件1:x<0
    • 条件2:0<=x<=m
    • 条件3:m<x
  • code 1:
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
const int maxn = 100010;
struct Node{
	int data, add, next;
}node[maxn];
vector<Node> tmp, ans;
int main(){
	int first, n, m, ta;
	scanf("%d %d %d", &first, &n, &m);
	for(int i = 0; i < n; ++i){
		scanf("%d", &ta);
		scanf("%d %d", &node[ta].data, &node[ta].next);
		node[ta].add = ta;	
	}
	while(first != -1){
		tmp.push_back(node[first]);
		first = node[first].next;
	}
	for(int i = 0; i < tmp.size(); ++i){
		if(tmp[i].data < 0) ans.push_back(tmp[i]);	
	}
	for(int i = 0; i <= m && i < tmp.size(); ++i){
		if(tmp[i].data >= 0 && tmp[i].data <= m) ans.push_back(tmp[i]);
	}
	for(int i = 0; i <= m && i < tmp.size(); ++i){
		if(tmp[i].data > m) ans.push_back(tmp[i]);
	}
	if(tmp.size() > m){
		for(int i = m+1; i < tmp.size(); ++i){
			if(tmp[i].data >= 0) ans.push_back(tmp[i]);
		}
	}
	for(int i = 1; i < ans.size(); ++i){
		printf("%05d %d %05d\n", ans[i-1].add, ans[i-1].data, ans[i].add);
	}
	printf("%05d %d -1\n", ans[ans.size()-1].add, ans[ans.size()-1].data);
	return 0;
}

标签:tmp,node,PAT,int,Splitting,ans,A1133,data,size
来源: https://blog.csdn.net/qq_42347617/article/details/100176478

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有