poj1033

模拟题,注意不需要移动的情况要特殊输出

#include <cstdio>
#include <cstring>
#include <cstdlib>
using namespace std;#define MAX_CLUSTER_NUM 10005int cluster_num, file_num;
int link[MAX_CLUSTER_NUM];
bool is_free[MAX_CLUSTER_NUM];
int total_length;
bool optimized;void input()
{memset(link, -1, sizeof(link));scanf("%d%d", &cluster_num, &file_num);for (int i = 0; i < cluster_num; i++)is_free[i] = true;int target_pos = 0;total_length = 0;for (int i = 0; i < file_num; i++){int file_part_num;scanf("%d", &file_part_num);total_length += file_part_num;for (int j = 0; j < file_part_num; j++){int original_pos;scanf("%d", &original_pos);original_pos--;link[target_pos] = original_pos;target_pos++;is_free[original_pos] = false;}}
}int drag(int start_point, int end_pos)
{optimized = true;int next_point;while (link[start_point] != end_pos){next_point = link[start_point];printf("%d %d\n", next_point + 1, start_point + 1);link[start_point] = -1;is_free[start_point] = false;is_free[next_point] = true;start_point = next_point;}return start_point;
}void work()
{optimized = false;for (int i = 0; i < total_length; i++)if (is_free[i])drag(i, -1);for (int i = 0; i < total_length; i++){if (link[i] != -1 && link[i] != i){printf("%d %d\n", i + 1, total_length + 1);is_free[i] = true;is_free[total_length - 1] = false;int last_pos = drag(i, i);link[last_pos] = -1;printf("%d %d\n", total_length + 1, last_pos + 1);is_free[last_pos] = false;is_free[total_length - 1] = true;}}if (!optimized)printf("No optimization needed\n");
}int main()
{input();work();return 0;
}
View Code

 

转载于:https://www.cnblogs.com/rainydays/p/3265433.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/300993.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ABP Framework V4.4 RC 新增功能介绍

新增功能概述•启动模板删除 EntityFrameworkCore.DbMigrations 项目•CMS-Kit 模块新增 动态菜单管理 功能•对象扩展管理系统新增两个扩展方法&#xff1a;MapEfCoreDbContext MapEfCoreEntity&#xff0c;分别对 数据上下文和实体 自定义映射配置。•文本模板系统新增 Razor…

《蛋白质女孩》的一句台词

《蛋白质女孩》的一句台词 有些女孩很真&#xff0c;有些很纯&#xff0c;有些很冷&#xff0c;有些很笨。有些像旋转门&#xff0c;有些像跑马灯&#xff0c;有些像聚宝盆&#xff0c;有些像地雷坑。有些可以私奔&#xff0c;有些敢爱敢恨&#xff0c;有些像多氯联苯&#xff…

linux快速切换目录命令,Linux在命令行快速切换目录 - 米扑博客

今天在微博上看到一个用命令行快速切换目录的文章&#xff0c;比之前自己的解决方案好了非常多&#xff0c;必须记录下来分享下。每天在命令行下&#xff0c;一大部分的工作都是一遍又一遍的输入 cd ~/some/very/deep/often-used/directory这样来切换目录&#xff0c;现在利用一…

论文排版怕翻车?这个排版神器赶紧用起来!

论文的重要加分点除了内容&#xff0c;还有它相信每年临近准备毕设或者毕业论文的同学会遇到这些问题&#xff1a;“我的毕业论文提交一次就被导师批评一次&#xff0c;内容不行就算了&#xff0c;格式也有问题&#xff01;改论文改到绝望”“期刊的版式要求不是统一的&#xf…

[正则表达式] 可以解析HTML/XHTML页面的所有元素和结构的Regular Expression![ZT]

ZT: http://www.cnblogs.com/Laser_Lu/archive/2005/04/21/142605.html哈哈&#xff0c;继 昨天的那个正则表达式 之后又写了一个更长的Regular Expression&#xff0c;全长527&#xff0c;是用于查找出所有的XHTML/HTML的标记外面的所有空格&#xff0c;并将之转换为 的。 希望…

linux查看mq是否启动的命令,rocketmq查看命令

1.1. 控制台使用RocketMQ 提供有控制台及一系列控制台命令&#xff0c;用于管理员对主题&#xff0c;集群&#xff0c;broker 等信息的管理&#xff1b;登录控制台首先进入RocketMQ 工程&#xff0c;进入/RocketMQ/bin在该目录下有个mqadmin 脚本查看帮助在mqadmin 下可以查看有…

我用段子讲.NET之依赖注入(一)

我用段子讲.NET之依赖注入&#xff08;一&#xff09;1&#xff09;西城的某个人工湖畔&#xff0c;湖水清澈见底&#xff0c;湖畔柳树成荫。人工湖往北&#xff0c;坐落着两幢写字楼&#xff0c;水晶大厦靠近地铁站&#xff0c;由于为了与湖面天际线保持一致&#xff0c;楼层只…

教师节,老师们最大的愿望竟然是。。 | 今日最佳

全世界只有3.14 % 的人关注了青少年数学之旅&#xff08;视频源网络&#xff0c;侵权删&#xff09;发给最敬爱的老师们↓ ↓ ↓

计算几何题集

这段时间刷了一群计算几何题&#xff0c;呼&#xff01; 做计算几何时一定要保证自己做到以下两点&#xff1a; 1.下手之前保证自己已经考虑到每一个细节&#xff0c;每一步的作法都要非常清晰。 2.敲代码时必须非常冷静&#xff0c;必须保持头脑清醒&#xff0c;保证自己敲下来…

linux文件权限 705,Linux 文件权限 - osc_86eb7mly的个人空间 - OSCHINA - 中文开源技术交流社区...

文件权限Linux 中任何一个文件都具有 「用户、用户组与其他用户」三种权限&#xff0c;一个用户可属于多个用户组。所有用户的相关信息都记录在 /etc/passwd 文件中&#xff0c;密码记录在 /etc/shaodw 文件&#xff0c;用户组记录在 /etc/group 文件。root 用户权限最高&#…

在.NET中获取一台电脑名,IP地址及当前用户名

在.NET中获取一台电脑名&#xff0c;IP地址及当前用户名是非常简单&#xff0c;以下是我常用的几种方法,如果大家还有其他好的方法&#xff0c;可以回复一起整理&#xff1a; 1. 在ASP.NET中专用属性&#xff1a; 获取服务器电脑名&#xff1a;Page.Server.ManchineName 获取用…

.net core 嵌入 js(javascript)脚本引擎

漂亮的目录1、万能的脚本2、内部嵌入引擎方式3、调用NodeJs服务&#xff0c;与之通信方式结论1、万能的脚本折腾无止境&#xff0c;.net core 提供了更多的可能&#xff0c;今天我们就来看看脚本引擎。提起脚本&#xff0c;不得不说说Javascript——WEB互联网世界的一大半江山都…

linux文件目录的管理,Linux文件目录管理

1、目录与路径相对路径与绝对路径绝对路径&#xff1a;路径的写法『一定由根目录 / 写起』&#xff0c;例如&#xff1a;/usr/share/doc这个目录相对路径&#xff1a;路径的写法『不是由根目录/写起』&#xff0c;例如&#xff1a; /usr/share/doc 要到/usr/share/man/底下时&a…

用一个小球揭开地球的面纱,探索地球运转的秘密!

一个人一旦对某事物有了浓厚的兴趣&#xff0c;就会主动去求知、去探索、去实践&#xff0c;并在求知、探索、实践中产生愉快的情绪和体验。所以&#xff0c;古今中外的教育家无不重视兴趣在智力开发中的作用。小木之前推荐过一款AR地球仪&#xff0c;它是一个互动性强、内容丰…

Eclipse C++的配置问题launch failed binary not found

首先下载eclipse c 我的是64bit版本 安装好MinGW&#xff0c;并配置好环境变量&#xff0c;参考我的博客 http://www.cnblogs.com/fickleness/p/3273044.html 配置eclipse 选executable,选mingw gcc .按make toolchain(s) preferred.ok 配置好关闭eclipse 然后 1、安装minGW先 …

最早的一副对联

公元964年&#xff08;后蜀广政二十七年&#xff09;春节前夕&#xff0c;后蜀主孟昶突然下了一道命令&#xff0c;要群臣在“桃符板”&#xff08;画有神像的桃木板&#xff0c;旧时认为可以避邪&#xff09;上题写对 句&#xff0c;以试才华。可是&#xff0c;当群臣们把对句…

张善友: .NET社区运营 | 2021 中国开发者生态峰会

内容来源&#xff1a;2021 年 6 月 5 日&#xff0c;由 SegmentFault 思否主办的 2021 中国开发者生态峰会圆满落幕。会上&#xff0c; .NET基金会成员、资深.NET顾问和解决方案专家张善友发表了主题为《 .NET社区运营》的演讲&#xff0c;以社区工程师的角度分享了 .NET社区发…

linux创建目录目录文件,Linux创建目录和文件管理教程

有时候我们需要在一块物理网卡上配置多个IP地址&#xff0c;这时就可以用到“子接口”的概念&#xff0c;这篇文章使用CentOS演示如何针对某块物理网卡创建子接口(在一些参考资料中&#xff0c;“子接口”有时也被称作“IP别名”)。有关Linux网络配置的基础知识&#xff0c;接下…

到底要不要拯救地球?真·逻辑鬼才!| 今日最佳

全世界只有3.14 % 的人关注了青少年数学之旅真逻辑鬼才↓ ↓ ↓

深入理解Magento-第十章-数据操作数据收集器

在我们开始介绍数据操作前&#xff0c;我们先介绍一个神兵利器—Varien Data Collections。在最早的时候我们写php通常用Array来做数据收集器&#xff0c;这个小东西可发挥了大作用&#xff0c;要知道如果你想在其他语言中实现Array有多么难过。例如c、c&#xff0b;&#xff0…