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

力扣周赛置换环的应用,最少交换次数

置换环的基本概念

置换环是排列组合中的一个概念,用于描述数组元素的重排过程。当我们需要将一个数组转换为另一个数组时,可以把这个转换过程分解为若干个 “环”。每个环代表一组元素的循环交换路径。

举个简单例子

假设原数组 A = [3, 2, 1, 4],目标数组 B = [1, 2, 3, 4](即按升序排序)。
我们需要将 A 转换为 B,可以通过以下步骤分析:

确定每个元素的目标位置:

        1.原数组 A[0]=3,在目标数组 B 中应该位于索引 2(值为 3 的位置。

        2.原数组 A[2]=1,在目标数组 B 中应该位于索引 0(值为 1 的位置。

        3.这形成了一个环:索引 0 → 索引 2 → 索引 0,对应的值为 3 → 1 → 3

其他元素

原数组 A[1]=2 和 A[3]=4 已经在正确位置,各自形成长度为 1 的环

环的结构
环1:0 → 2 → 0 (长度2)
环2:1 → 1 (长度1)
环3:3 → 3 (长度1)

重要结论

将一个环排序所需的最小交换次数 = 环的长度 - 1。

最少总交换次数 = 总元素数 - 环的数量

来看一道字节跳动的力扣周赛

int getSum(int x){int ret=0;while(x){ret=ret+x%10;x/=10;}return ret;}
bool comp(const pair<int,int>&p1,const pair<int,int>& p2){int num1=getSum(p1.first);int num2=getSum(p2.first);if(num1==num2){return p1.first<p2.first;}else{return num1<num2;}
}
class Solution {
public:int minSwaps(vector<int>& nums) {int len=nums.size();vector<pair<int,int>> arr;for(int i=0;i<len;i++){arr.push_back({nums[i],i});}sort(arr.begin(),arr.end(),comp);vector<int> table(nums.size());for(int i=0;i<arr.size();i++){table[arr[i].second]=i;}vector<bool> visited(len,false);int circles=0;for(int i=0;i<len;i++){if(!visited[i]){int cur=i;circles++;while(!visited[cur]){visited[cur]=true;cur=table[cur];}}}return len-circles;//元素总数-环的数量}
};

http://www.lryc.cn/news/2383307.html

相关文章:

  • 大语言模型 12 - 从0开始训练GPT 0.25B参数量 MiniMind2 补充 训练开销 训练步骤 知识蒸馏 LoRA等
  • hgdbv9创建plpython3u插件后无法使用该插件创建函数
  • SQLMesh 宏操作符详解:@IF 的条件逻辑与高级应用
  • nt!MiRemovePageByColor函数分析之脱链和刷新颜色表
  • 【爬虫】12306自动化购票
  • 不同消息队列保证高可用实现方案
  • 【Django系统】Python+Django携程酒店评论情感分析系统
  • spring cloud alibaba-Geteway详解
  • c#中添加visionpro控件(联合编程)
  • 性能测试-mysql监控
  • 游戏引擎学习第301天:使用精灵边界进行排序
  • CSS attr() 函数详解
  • 【AI生成PPT】使用ChatGPT+Overleaf自动生成学术论文PPT演示文稿
  • 流复备机断档处理
  • Linux 安装 pytorch+cuda+gpu 大模型开发环境过程记录
  • 局部放大maya的视图HUD文字大小的方法
  • 数学复习笔记 16
  • 初识Linux · NAT 内网穿透 内网打洞 代理
  • STM32接收红外遥控器的遥控信号
  • Redis从入门到实战 - 高级篇(下)
  • NGINX常用功能—笔记
  • JVM 性能问题排查实战10连击
  • 【jvm第8集】jvm调优工具(图形化工具)
  • Python测试单例模式
  • 多技术栈 iOS 项目的性能调试实战:从 Flutter 到 Unity(含 KeyMob 工具实测)
  • STM32简易计算机设计
  • GUI实验
  • 量子计算 | 量子密码学的挑战和机遇
  • linux系统查看硬盘序列号
  • 分享一些多模态文档解析思路