`
leili
  • 浏览: 180781 次
社区版块
存档分类
最新评论

POJ1033

阅读更多

题目链接:http://poj.org/problem?id=1033

 

package D0807;/*题目大意:给你有几个文件以及文件碎片现在的位置,要求给出操作方法, * 使得操作之后文件连续并且紧凑还有总体上文件时按照顺序摆放的。 * 例如样例:20 3 表示20个空间,3个文件4 2 3 11 12  * 第一个文件有4个碎片,分别在2,3,11,121 7 后面的一样 * 初始目标状态是:1~4是一号文件的碎片,5号是2号文件的碎片,6~8是3号文件的碎片...总之模拟碎片整理程序。 * 有2种不和谐因素:出现了环,或者链。 * 怎么说呢?环是指一些碎片,上一个碎片占据了下一个碎片应有的位置。然后最后一个占据了第一个位置。 * 而链就是最后一个的目标位置是空闲的 * */import java.util.*;import java.io.*;public class POJ1033 {	static int clusters[] = new int[10001];   	static int clusters_num, file_num;   	static int counter = 1, move_num = 0;//文件片段的真实编号和操作的总数   	static int next, i, j, t, n;   	static Stack<Integer>s = new Stack<Integer>();	static PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));	public static void main(String[] args) throws IOException {		StreamTokenizer st = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));				st.nextToken();		clusters_num = (int) st.nval;		st.nextToken();		file_num = (int) st.nval;		for (i = 0; i < file_num; i++) {			st.nextToken();			n = (int)st.nval;			for(j = 0;j<n;j++){				st.nextToken();				t = (int)st.nval;				clusters[t] = counter++;			}		}		doit();		out.flush();	}	private static void doit() {		// TODO Auto-generated method stub		for(i = 1;i<=clusters_num;i++){			if(clusters[i]==i)continue;//如果刚好放在了目标位置上就不需要移动。			else if(clusters[i]!=0){//位置上放了文件且位置错误				s.push(i);				next = clusters[i];								boolean is_circle = false;				while(true){//判断是否出现了环					if(clusters[next]==i){						is_circle = true;						break;					}else if(clusters[next]==0){						is_circle = false;						break;					}					s.push(next);					next = clusters[next];				}				if(is_circle){					for(j = clusters_num; j>=0; j--){						if(clusters[j]==0)break;//从后向前找一个空位置,为解开环做准备					}					//System.out.println(next+" "+j);					out.println(next+" "+j);					clusters[j] = clusters[next];					deal();					clusters[next] = clusters[j];//把开始的结点移动回去  					clusters[j] = 0;					//System.out.println(j+" "+next);					out.println(j+" "+next);				}else{//没有环					deal();					clusters[next] = 0;				}			}		}		if(move_num==0)//System.out.println("No optimization needed");			out.println("No optimization needed");			}	private static void deal() {		// TODO Auto-generated method stub		while(!s.isEmpty()){			t  = s.peek();			//System.out.println(t+" "+next);			out.println(t+" "+next);			clusters[next] = clusters[t];			next = t;			s.pop();			move_num++;		}			}}


 

分享到:
评论

相关推荐

    S变换+Sockwell R G , Mansinha L , Lowe R P . Localization of the complex spectrum: the S transformJ

    s变换用的高斯窗函数( 高斯窗是指数窗的一种,它也无负的旁瓣,而且没有旁瓣波动,因而不回引起计算谱中假的极大值或极小值,而且高斯窗频率窗函数的主瓣比指数窗的主瓣窄,分辨率比指数窗有所提高。

    2021科大讯飞车辆贷违预测大赛冠军源码+全部资料.zip

    2021科大讯飞车辆贷违预测大赛冠军源码+全部资料.zip [资源说明] 1、该项目是团队成员近期最新开发,代码完整,资料齐全,含设计文档等 2、上传的项目源码经过严格测试,功能完善且能正常运行,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的高校学生、教师、科研工作者、行业从业者下载使用,可借鉴学习,也可直接作为毕业设计、课程设计、作业、项目初期立项演示等,也适合小白学习进阶,遇到问题不懂就问,欢迎交流。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 5、不懂配置和运行,可远程教学 欢迎下载,学习使用!

    AI图像处理工具包-一键抠图、背景切换、旧照片修复、人像漫画化、视频卡通化(Python+OpenCV+Dlib+TensorFlow).zip

    AI图像处理工具包-一键抠图、背景切换、旧照片修复、人像漫画化、视频卡通化(Python+OpenCV+Dlib+TensorFlow).zip [资源说明] 1、该项目是团队成员近期最新开发,代码完整,资料齐全,含设计文档等 2、上传的项目源码经过严格测试,功能完善且能正常运行,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的高校学生、教师、科研工作者、行业从业者下载使用,可借鉴学习,也可直接作为毕业设计、课程设计、作业、项目初期立项演示等,也适合小白学习进阶,遇到问题不懂就问,欢迎交流。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 5、不懂配置和运行,可远程教学 欢迎下载,学习使用!

    基于java+springboot+vue+mysql的远程教育网站设计与实现.docx

    基于java+springboot+vue+mysql的远程教育网站设计与实现.docx

    springboot005学生心理咨询评估系统(源码+数据库+论文+PPT+包调试+一对一指导)

    毕业设计资料,计算机毕业设计,源码,毕业论文,毕业答辩,答辩PPT,Java毕业设计,php毕业设计,ASP.NET毕业设计,毕业指导,计算机作业,php作业,java作业,ASP.NET作业,编程作业,管理系统,网站,app,毕业设计学习,Java学习,php学习,ASP.NET学习,java课程,php课程,ASP.NET课程,答辩技巧,SQLSERVER数据库,Mysql数据库,jdbc,SSM框架,SpringBoot框架,Html5,小程序

    蓝牙串口助手,可以连接HC-05等蓝牙模块,实现单片机设备与手机通讯,安卓手机,蓝牙调试助手,具有按键功能!

    蓝牙串口助手,可以连接HC-05等蓝牙模块,实现单片机设备与手机通讯,安卓手机,蓝牙调试助手,具有按键功能!

    TriLib-2-Model-Loading-Package-2.3.7.unitypackage

    TriLib 2 是一个跨平台的运行时 3D 模型导入器

    “人力资源+大数据+薪酬报告+涨薪调薪”

    人力资源+大数据+薪酬报告+涨薪调薪,在学习、工作生活中,越来越多的事务都会使用到报告,通常情况下,报告的内容含量大、篇幅较长。那么什么样的薪酬报告才是有效的呢?以下是小编精心整理的调薪申请报告,欢迎大家分享。相信老板看到这样的报告,一定会考虑涨薪的哦。

Global site tag (gtag.js) - Google Analytics