当前位置: 首页 > wzjs >正文

湛江网站制作百度2022第三季度财报

湛江网站制作,百度2022第三季度财报,wordpress code editor,asp网站连不上数据库1 题目:情侣牵手 官方标定难度:难 n 对情侣坐在连续排列的 2n 个座位上,想要牵到对方的手。 人和座位由一个整数数组 row 表示,其中 row[i] 是坐在第 i 个座位上的人的 ID。情侣们按顺序编号,第一对是 (0, 1)&#…

1 题目:情侣牵手

官方标定难度:难

n 对情侣坐在连续排列的 2n 个座位上,想要牵到对方的手。

人和座位由一个整数数组 row 表示,其中 row[i] 是坐在第 i 个座位上的人的 ID。情侣们按顺序编号,第一对是 (0, 1),第二对是 (2, 3),以此类推,最后一对是 (2n-2, 2n-1)。

返回 最少交换座位的次数,以便每对情侣可以并肩坐在一起。 每次交换可选择任意两人,让他们站起来交换座位。

示例 1:

输入: row = [0,2,1,3]
输出: 1
解释: 只需要交换row[1]和row[2]的位置即可。
示例 2:

输入: row = [3,2,0,1]
输出: 0
解释: 无需交换座位,所有的情侣都已经可以手牵手了。

提示:

2n == row.length
2 <= n <= 30
n 是偶数
0 <= row[i] < 2n
row 中所有元素均无重复

2 solution

将需要交换位置的情侣合并成一个个小集合,每个集合为一个环,即
A ->B->C->A, 每个环交换 m - 1 次,m 为环的大小

代码

class Solution {
public:int minSwapsCouples(vector<int> &row) {int n = row.size() / 2;int f[n];for (int i = 0; i < n; i++) {f[i] = i;}auto const find = [&](auto self, int x) {if (f[x] == x) return x;return f[x] = self(self, f[x]);};for (int i = 0; i < n; i++) {int x = row[i * 2] / 2;int y = row[i * 2 + 1] / 2;int p = find(find, y);int q = find(find, x);if(p != q){f[p] = q;}}vector<int> cnt(n);for(int i = 0; i < n; i++) cnt[find(find, i)]++;int sum = 0;for(int x:cnt) if(x) sum += x - 1;return sum;}
};

结果

在这里插入图片描述

http://www.dtcms.com/wzjs/259897.html

相关文章:

  • 网站诊断分析报告模板及优化执行方案.doc西安疫情最新消息
  • 网站设计与管理论文重庆网站搜索排名
  • 产品服务展示型网站有哪些网站关键词排名优化价格
  • 可以自建网站吗四川seo优化
  • 网站建设实训总结报告深圳优化公司找高粱seo服务
  • 做网站公司(信科网络)企业营销型网站
  • 做一个网站大概多少钱如何做好网络销售技巧
  • 克隆网站首页做单页站几个文件夹线上营销
  • 太原企业做网站google怎么推广
  • 以下是b2b电子商务网站seo网站推广多少钱
  • 沧州高端网站建设恶意点击推广神器
  • 顺德网站建设怎么样代写文章的平台有哪些
  • 关于做好学院网站建设的要求在线seo优化
  • 深圳市做网站武汉网站设计十年乐云seo
  • 淘宝网站建设目标郴州网站seo外包
  • 国家骨干院校建设网站销售培训
  • 义乌专业做网站济南网站优化
  • 甘肃企业网站建设html友情链接
  • 优秀网站免费网站建设哪个好
  • 南京手机网站设计个人博客网站设计毕业论文
  • 做动态图片的网站吗安卓优化大师旧版本下载
  • 中文网站建设中模板在线的crm系统软件
  • 阿里云网站空间购买网店关键词怎么优化
  • 为网站吸引流量的方法郑州网络营销排名
  • 手机网站大小2345纯净版推广包
  • 网站建设零基础自学视频教程设计外包网站
  • 佛山网站建设优势网站免费发布与推广
  • 公司做网站费用计什么科目网上推广赚钱方法
  • 昆明网站建设天猫运营2022十大网络营销案例
  • 网站如何做超级链接手机百度下载免费安装