招行FT训练营笔试第二题题解

招行笔试第二题是leetcode第765题:情侣牵手。
这题要求最少移动个数,我们通过贪心算法来解决。
贪心算法即为先通过交换让第一对情侣在一起,然后在看第二对,依次遍历所有数据。
对本题来讲,每组数是较小的偶数和大1的奇数,两者位置可互换。所以解题时,我们先判别每组的第一个数是偶数还是奇数。如果是偶数,往后找到比它大1 的奇数,然后与该组第二个数交换。如果是奇数,往后找到比它小1 的偶数,然后与该组第二个数交换。总的时间复杂度为O(n*n)。

int minSwapsCouples(vector<int>& row)
{
	int cnt=0; 
	for(int i=1;i<row.size();i=i+2)
	{
		if((row[i-1]&1)==0)
		{
	      if((row[i-1]+1)!=row[i]) 
	       {
	          for(int j=i+1;j<row.size();j++)
		     {
		       if(row[j]==(row[i-1]+1))
			   {
			      swap(row[i],row[j]);
				  cnt++;
			   }
		     }
	       }
		}
		else 
		{
			if((row[i-1])!=(row[i]+1)) 
	       {
	          for(int j=i+1;j<row.size();j++)
		     {
		       if(row[i-1]==(row[j]+1))
			   {
			      swap(row[i],row[j]);
				  cnt++;
			   }
		     }
		  }
		  }
	   }
	return cnt;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值