| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 834 人关注过本帖
标题:太冷清,给大家个小挑战
只看楼主 加入收藏
zjxtx4431
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2007-8-31
收藏
 问题点数:0 回复次数:3 
太冷清,给大家个小挑战

废话比较多,大家先看看^^
noip05第3题
佳佳刚进高中,在军训的时候,由于佳佳吃苦耐劳,很快得到了教官的赏识,成为了“小教官”。在军训结束的那天晚上,佳佳被命令组织同学们进行篝火晚会。一共有n个同学,编号从1到n。一开始,同学们按照1,2,……,n的顺序坐成一圈,而实际上每个人都有两个最希望相邻的同学。如何下命令调整同学的次序,形成新的一个圈,使之符合同学们的意愿,成为摆在佳佳面前的一大难题。

佳佳可向同学们下达命令,每一个命令的形式如下:

(b1, b2,... bm -1, bm)

这里m的值是由佳佳决定的,每次命令m的值都可以不同。这个命令的作用是移动编号是b1,b2,…… bm –1,bm的这m个同学的位置。要求b1换到b2的位置上,b2换到b3的位置上,……,要求bm换到b1的位置上。

执行每个命令都需要一些代价。我们假定如果一个命令要移动m个人的位置,那么这个命令的代价就是m。我们需要佳佳用最少的总代价实现同学们的意愿,你能帮助佳佳吗?

【输入文件】

输入文件fire.in的第一行是一个整数n(3 <= n <= 50000),表示一共有n个同学。其后n行每行包括两个不同的正整数,以一个空格隔开,分别表示编号是1的同学最希望相邻的两个同学的编号,编号是2的同学最希望相邻的两个同学的编号,……,编号是n的同学最希望相邻的两个同学的编号。

【输出文件】

输出文件fire.out包括一行,这一行只包含一个整数,为最小的总代价。如果无论怎么调整都不能符合每个同学的愿望,则输出-1。

【样例输入】

4
3 4
4 3
1 2
1 2

【样例输出】
2
【数据规模】


对于30%的数据,n <= 1000;

对于全部的数据,n <= 50000。

对于这道题目,我用一个数组模拟出了在可能完成任务的前提下最后排好序的情况如样例中我就恢复成了
1 3 2 4
然后就相当于按题目要求把它恢复成 1 2 3 4所需要的最少调动次数
有分析说是用冒泡排序记录交换次数,可我尝试过后发现那远大于最优答案
求教!

搜索更多相关主题的帖子: 挑战 
2007-09-01 13:26
hangeng
Rank: 2
等 级:论坛游民
帖 子:424
专家分:39
注 册:2007-7-23
收藏
得分:0 

请问你的"b1"中的"1"和其他的,是下标吗?


  雨水冲不进窗来,在玻璃上痛哭。但它至少奋斗过。
2007-09-01 21:51
leeco
Rank: 4
等 级:贵宾
威 望:10
帖 子:1029
专家分:177
注 册:2007-5-10
收藏
得分:0 

有地方能JUDGE吗?我只想到了n^2的算法



#include <iostream>
using namespace std;

int adjlist[50000+1][2];
int a[50000+1];
int used[50000+1];

int main()
{
int n,t1,t2;
while(scanf(\"%d\",&n)!=EOF){
for(int i=1;i<=n;i++){
scanf(\"%d%d\",&adjlist[i][0],&adjlist[i][1]);
}
int flag=1;
for(int i=1;i<=n;i++){
if(adjlist[adjlist[i][0]][0]!=i && adjlist[adjlist[i][0]][1]!=i){
flag=0;
break;
}
}
if(!flag){
printf(\"-1\n\");
}
else {
memset(used,0,sizeof(used));
a[1]=1;
used[1]=1;
for(int i=2;i<=n;i++){
if(!used[adjlist[a[i-1]][0]]){
a[i]=adjlist[a[i-1]][0];
used[adjlist[a[i-1]][0]]=1;
}
else {
a[i]=adjlist[a[i-1]][1];
used[adjlist[a[i-1]][1]]=1;
}
}

int min=INT_MAX;
for(int d=0;d<n;d++){
int cnt1=0,cnt2=0;
for(int i=1;i<=n;i++){
if(a[(i+d-1+n)%n+1]==i)cnt1++;
if(a[(i-d-1+n)%n+1]==i)cnt2++;
}
min<?=n-cnt1;
min<?=n-cnt2;
}
printf(\"%d\n\",min);
}
}
}


2007-09-02 00:34
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
收藏
得分:0 
以前看过,冒泡排序AC

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2007-09-02 10:02
快速回复:太冷清,给大家个小挑战
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016818 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved