2020.02.13普及C组模拟赛6(第一题)

1.晾衣绳

题目描述

奶牛们用N(1<=N<=1000)根绳子架起了晾衣绳,以便晒它们刚洗完的衣服。用它们不能弯曲的拇指,奶牛们彻底搞砸了这项工作。试想一下四根绳子是这样排列的:
在这里插入图片描述
绳子交叉了!这个,当然是无法接受的。

奶牛们想把晾衣绳整理好。它们迟钝的头脑只能处理"交换两根绳"的问题。然而奶牛们的手臂(牛的……也叫手臂)很短,受此限制,它们只能交换相邻两根绳子的端点(在上面或者是下边的固定器上)。以上面的图为例,需要做四次这样的交换才能使绳子变成想下面这样:
在这里插入图片描述
帮助奶牛们整理晾衣绳吧。请你找出最小的交换次数,使得这些晾衣绳能够排列整齐。

你将得到有关晾衣绳位置的描述,用整数来表示当前晾衣绳的顺序。这些晾衣绳被标上了1…N的数字。现在可以告诉你的是,这些晾衣绳在上面和下面各N个连接插槽上的出现顺序。

输入

第1行:一个整数N

第2…N+1行:

每一行有两个隔开的整数(均在1…N范围内)。第一个整数表示在上插槽上连接的绳子的ID,第二个整数表示在下插槽上连接的绳子的ID。第二行的两个整数就分别表示了1号上插槽和1号下插槽上连接的绳子;第三行则分别描述了2号上插槽和下插槽上连接的绳子……以此类推。

输出

第1行:一个整数,指出可以把晾衣绳全都弄直的最小交换次数

样例输入

4

4 1

2 3

1 4

3 2

样例输出

4

数据范围限制

1<=N<=1000

提示

样例说明

把3号绳上面的端点和它左边的交换,再和左边的交换一次。4号绳也做同样的工作。

正解
看题目中说,只能交换相邻两个端点,就能想到用冒泡排序
先记录每条绳子的位置,再冒泡排序,每排一次结果就+1

#include<iostream> 
#include<cstdio>
using namespace std;
int n,x,s,a[1005],b[1005];
void jh(int i,int x)
{ 
    int o=a[i]; 
    for(int j=x;j>i;j--)//交换 
    { 
        a[j]=a[j-1]; 
        s++;  
    } 
    a[i]=o;//回初值
}
int main()
{ 
    freopen("laundry.in","r",stdin); 
    freopen("laundry.out","w",stdout);
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i]>>b[i];
    for(int i=1;i<=n;i++) 
    { 
        if(b[i]!=a[i]) //如果不相等就要交换了
        for(int j=i;j<=n;j++) 
         if(a[j]==b[i]){jh(i,j);break;} 
        x=1;
        for(int i=1;i<=n;i++)//判断是否全部相等
         if(a[i]!=b[i]){x=0;break;}
		if(x==1)break; 
    } 
    cout<<s<<endl;
    return 0;
}

下面附本次比赛的其他题目

2020.02.13普及C组模拟赛6(第一题)
2020.02.13普及C组模拟赛6(第二题)
2020.02.13普及C组模拟赛6(第三题)
2020.02.13普及C组模拟赛6(第四题)
2020.02.13普及C组模拟赛6(总结)

谢谢观看

发布了65 篇原创文章 · 获赞 93 · 访问量 1847

猜你喜欢

转载自blog.csdn.net/weixin_45524309/article/details/104542837