交换数组的索引值和元素值

在一次笔试中遇到编程题,要求交换数组的索引值和元素值。通过使用HashMap实现,起初因误解Map的无序性导致思路复杂,后来发现其实很简单。首先将数据存入Map,然后遍历原数组并更新元素值。另一种高效方法是创建新数组,按索引值赋值。理解Map的无序性是关键,它并不影响本题的解决方案。解决问题时要保持冷静,避免将简单问题复杂化。
摘要由CSDN通过智能技术生成

在参加笔试时候有这样一个编程题:有这样一个由0到N-1的正整数数组,交换一个数组的索引值和元素值,例如输入的是数组{2,4,5,1,0,3},返回一个数组输出是{4,3,0,5,1,2},因为在测试用例的时候已经规定了是元素唯一不重复,所以想到了使用HashMap进行转化,由于一开始理解错了Map的不保证顺序,以至于思路十分的繁杂未能通过测试,考试过后安静下来想了一下,用map实现了这个问题,十分之简单,记录下来一方面是作为一个基础知识不扎实的教训,另一方面也告诫自己不要把简单的问题复杂化。

public static int[] swapArr(int[] arr){
Map<Integer, Integer> temp=new HashMap<Integer, Integer>();
    ArrayList<Integer> aList=new ArrayList<Integer>();
    int[] result=new int[arr.length+1]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值