交替放置的碟子

首先把问题转化一下,用1表示黑碟子,0表示白碟子,那么目前的顺序是:
1010…1010
结果要求1都放在右边,0都放在左边。这个题目看起来很眼熟。看关键字:交换相邻的碟子,排好顺序。嗯,就是经常出现在面试中的冒泡排序了。
为便于观察,假设目前有6个碟子:101010。使用冒泡排序,第一次迭代,碟子序列变为:010101,交换3次。在进行第二次迭代之前,观察一下。
现在,不仅第一个碟子就位,最后一个也是了,因此第二次迭代只需要对第2到第5个进行排序,巧合的是,碟子[2->5]仍然是10交替出现,不过比上一次少了两个,这样就简单了,可以得到结论:对于2n个碟子,可以使用n次迭代完成,交换的次数分别是:n+(n-1)+…+2+1,即n(n+1)/2。


#include<bits/stdc++.h>
using namespace std;
int n; 
int k;
void mv(int j)
{
	printf("%d,%d-->%d,%d\n",j,j+1,k,k+1);
	k=j;
}
void dfs(int n)
{
	if(n==4)
	{
		mv(4);mv(8);mv(2);mv(7);mv(1);
	}
	else
	{
		mv(n);mv(2*n-1);dfs(n-1);
	}
}
int main()
{
	cin>> n;
	k=2*n+1;
	dfs(n);
} 



在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值