这篇文章主要讲解了“用Java怎么排序两个数组”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“用Java怎么排序两个数组”吧!
假设有 number,group,两个数组,其中的元素都是数字,现在要对其排序排序的规则如下:
1.如果 group里面元素,存在于numbers了里面
2.要把出现在 group 内的数字 放在 number 的那些数字之前,注意排序
numbers = [8, 3 ,1, 2, 5,4,7,6] group = {2,3,5,7}
分析了下,应该是优先级的问题,这里使用了元组排序的方法:
numbers = [8, 3 ,1, 2, 5,4,7,6] group = {2,3,5,7} tmp = [] for x in numbers: if x in group: tmp.append((0, x)) else: tmp.append((1, x)) tmp.sort() print(list(map(lambda x:x[1], tmp)))
在网上看到了一个经典的代码:
def sort_priority(values,group): def helper(x): if x in group: return (0, x) return (1, x) values.sort(key=helper) numbers = [8, 3 ,1, 2, 5,4,7,6] group = {2,3,5,7} sort_priority(numbers, group) print(numbers)
推荐使用第二个高阶函数的方法
感谢各位的阅读,以上就是“用Java怎么排序两个数组”的内容了,经过本文的学习后,相信大家对用Java怎么排序两个数组这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/209348.html