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

【算法题】2191. 将杂乱无章的数字排序

题目:

给你一个下标从 0 开始的整数数组 mapping ,它表示一个十进制数的映射规则,mapping[i] = j 表示这个规则下将数位 i 映射为数位 j 。

一个整数 映射后的值 为将原数字每一个数位 i (0 <= i <= 9)映射为 mapping[i] 。

另外给你一个整数数组 nums ,请你将数组 nums 中每个数按照它们映射后对应数字非递减顺序排序后返回。

注意:

如果两个数字映射后对应的数字大小相同,则将它们按照输入中的 相对顺序 排序。
nums 中的元素只有在排序的时候需要按照映射后的值进行比较,返回的值应该是输入的元素本身。

示例 1:

输入:mapping = [8,9,4,0,2,1,3,5,7,6], nums = [991,338,38]
输出:[338,38,991]
解释:
将数字 991 按照如下规则映射:

  1. mapping[9] = 6 ,所有数位 9 都会变成 6 。
  2. mapping[1] = 9 ,所有数位 1 都会变成 8 。
    所以,991 映射的值为 669 。
    338 映射为 007 ,去掉前导 0 后得到 7 。
    38 映射为 07 ,去掉前导 0 后得到 7 。
    由于 338 和 38 映射后的值相同,所以它们的前后顺序保留原数组中的相对位置关系,338 在 38 的前面。
    所以,排序后的数组为 [338,38,991] 。
    示例 2:

输入:mapping = [0,1,2,3,4,5,6,7,8,9], nums = [789,456,123]
输出:[123,456,789]
解释:789 映射为 789 ,456 映射为 456 ,123 映射为 123 。所以排序后数组为 [123,456,789] 。

提示:

mapping.length == 10
0 <= mapping[i] <= 9
mapping[i] 的值 互不相同 。
1 <= nums.length <= 3 * 10^4
0 <= nums[i] < 10^9

java代码:

class Solution {
    public int[] sortJumbled(int[] mapping, int[] nums) {
		//二维数组,copy[i][0]:保存数据的映射,copy[i][1]:保存数据的映射nums[i]
		
        int[][] copy=new int[nums.length][2];
		
		for (int i = 0; i < copy.length; i++) {
			copy[i][0]=nums[i];
			copy[i][1]=nums[i];
		}
		//对数据进行映射
		for (int i = 0; i < copy.length; i++) {
			Stack<Integer> stack=new Stack<>();
            if(copy[i][0]==0) stack.push(0);
			int tmp=0;
			while (copy[i][0]>0) {
				tmp=copy[i][0]%10;
				stack.push(tmp);
				copy[i][0]/=10;
			}
			tmp=0;
			while (!stack.isEmpty()) {
				tmp*=10;
				tmp+=mapping[stack.pop()];
			}
			copy[i][0]=tmp;
		}
		//排序
		Arrays.sort(copy,new Comparator<int[]>() {

			@Override
			public int compare(int[] o1, int[] o2) {
				return o1[0]-o2[0];
			}
		});
		
		for (int i = 0; i < copy.length; i++) {
			nums[i]=copy[i][1];
		}
		
		return nums;
    }
}

http://www.kler.cn/a/2582.html

相关文章:

  • [笔记] 使用 Jenkins 实现 CI/CD :从 GitLab 拉取 Java 项目并部署至 Windows Server
  • 【Optional 的 orElseGet 和 orElse区别】
  • Centos7 解决Maven scope=system依赖jar包没有打包到启动jar包中的问题(OpenCV-4.10)
  • C# XPTable 带图片的增删改查(XPTable控件使用说明十三)
  • ProtonBase 荣获 Datafun “数智技术最佳探索奖”
  • 使用WPF在C#中制作下载按钮
  • Spring教程——Spring IoC(控制反转)
  • Docker—苹果Mac安装Docker的两种方式
  • 真要被00后职场整顿了?老员工纷纷表示真的干不过.......
  • Java - 配置中心初体验
  • Nginx可视化管理工具 - Nginx Proxy Manager
  • three.js中创建文字(Creating text)
  • 难以置信,已经有人用 ChatGPT 做 Excel 报表了?
  • Spring Boot 3.0系列【22】应用篇之嵌入式 Servlet 容器
  • 离线安装ffmpeg
  • Centos7 XFS(dm-0):Internal error XFS_WANT_CORRUPTED_GOTO
  • Prometheus 监控云Mysql和自建Mysql(多实例)
  • ‘/’ 和 ‘%’ 在编程中的作用【附加练习题】
  • MFU(Mask Field Utilization)
  • 去中心化联邦学习-Python实现的2个案例
  • Windows Server 2022 中文版、英文版下载 (updated Mar 2023)
  • 【数据结构】排序
  • 0x03数学预备
  • sql语句总结
  • Unity设计模式—服务定位器模式
  • 【Vue全家桶】带你全面了解通过Vue CLI初始化Vue项目