java如何解决最少移动次数使数组元素相等的问题

发布时间:2022-01-17 14:50:50 作者:清风
来源:亿速云 阅读:147

这篇“java如何解决最少移动次数使数组元素相等的问题”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“java如何解决最少移动次数使数组元素相等的问题”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢理解,接下来就让我们进入主题吧。

给定一个非空整数数组,找到使所有数组元素相等所需的最小移动数,其中每次移动可将选定的一个元素加1或减1。您可以假设数组的长度最多为10000。

例如:

输入:
[1,2,3]

输出:
2

说明:

只有两个动作是必要的(记得每一步仅可使其中一个元素加1或减1):


[1,2,3]  =>  [2,2,3]  =>  [2,2,2]

答案:

1public int minMoves2(int[] nums) {
2    Arrays.sort(nums);
3    int i = 0, j = nums.length - 1;
4    int count = 0;
5    while (i < j) {
6        count += nums[j--] - nums[i++];
7    }
8    return count;
9}

解析:

这题其实更像是一道数学题,先来分析一下,我们假设把两个数a,b(a<=b)经过最少的转换最终变为x。这里有3种情况

1,x<=a,转变次数为(a-x)+(b-x)=(a+b)-2x;

2,a<=x<=b,转变次数为(x-a)+(b-x)=b-a;

3,x>=b,转变次数为(x-a)+(x-b)=2x-(a+b);

所以很明显第二种情况转换的次数是最少的,也就是说x在a和b之间的时候,转换的次数是最少的。我们可以使用极限法证明

1,当x=a时取最小值,最小值是(a+b)-2a=b-a;

3,当x=b时取最小值,最小值是2b-(a+b)=b-a;

所以这个问题就很好解决了,我们只需要把数组排好序,当数组长度为2的时候,只需要大的减小的即可,当数组长度为3的时候,我们只需要计算中间值与那两个数差的绝对值的和即可(或者是最后一个减去第一个),当数组长度为n的时候,我们只需要找到最中间值,然后每一个数与他的差的绝对值相加即可。

Java有哪些集合类

Java中的集合主要分为四类:1、List列表:有序的,可重复的;2、Queue队列:有序,可重复的;3、Set集合:不可重复;4、Map映射:无序,键唯一,值不唯一。

以上是“java如何解决最少移动次数使数组元素相等的问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. java bfs实现单词最少转换次数
  2. java string相等问题 常用方法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:如何使用java反转链表

下一篇:vue如何用Echarts画柱状图

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》