华为面试题(笔试,8分钟写出代码)

 题目:有两个数组a,b,大小都为n,数组元素的值任意,无序; 要求:通过交换a,b中的元素,使数组a元素的和与数组b元素的和之间的差最小 

先上代码
java代码:
public class MinDiff {
    public static void main(String[] args){
        int[] aa={2,5,4,3,1,0};
        int[] bb={7,9,8,10,6,11};
        exchange(aa,bb);

    }
    static void exchange(int[] a,int[] b){

        int n=a.length;
        int diff=0;
        for(int i=0;i<n;i++){
            diff+=a[i]-b[i];//计算两组数的差
        }
        for(int i=0;i<n;i++){
            for(int j=0;j<n;j++){
                int tp=a[i]-b[j];//计算两组数中单个元素的差值
                int t=tp-diff;//单个元素差值和数组的差值比较
                if(t*tp<0){    //以此条件判断是否需要交换
                    int ex=a[i];
                    a[i]=b[j];
                    b[j]=ex;
                    diff-=2*tp;//计算数据交换后两个数组的差值
                }
            }
        }
        for(int i=0;i<n;i++){
            System.out.println(a[i]+" "+b[i]);
        }
    }
}
前两天在“算法与数据结构”微信公众号上看到了这一题,当时看了下面的评论,感觉我如果一直不准备这方面的知识,我估计也会首先想到排序。
但是,这题说数据是无序的所以排序一定不是正确的方法。我的想法也不是一气呵成的,算是一点点试出来的。以下是我的思路。
首先,把问题简化,如果a,b两个数组长度为2,这题怎么做(别排序)取a={1,2},b={5,3}?
我的思路:
	1、分别计算a、b两个数组的元素之和suma和sumb,并求他们的差diff=suma-sumb(这里diff=-5);
	2、对单个元素进行操作,a[0]-b[0]=1-5=-4,这里a[0]和b[0]的差值小于a数组和b数组整体的差,交换他们,此时,a={5,2},b={1,3},diff=3;
 
	然后继续a[0]-b[1]=5-3=2,2<3=diff,交换a[0]和b[1],此时a={3,2},b={1,5},差值为diff=-1.到此,一次循环结束。
	3、按照步骤2的方法,把数组a的元素从头到尾和b数组中所有元素比较,直到最后一个数组元素。
以上就是我的思路。这里还有个问题:如何保证交换后两数组的差值一定会减小?
我们设diff为数组和的差,singlediff表示单个元素的差。我们先列举几种情况:
	1、diff=-5,singlediff=-4
	2、diff=-5,singlediff=-7
	3、diff=-5,singlediff=4
	4、diff=5,singlediff=-4
	5、diff=5,singlediff=7
	6、diff=5,singlediff=4
关于差值的情况我们举出来了,但是问题的关键是如何求数据交换后的新的差值newDiff?
就像代码里那样:newDiff=diff-2*singlediff
用上面6组数据带入求newDiff然后就能得到规律:(singlediff-diff)*single<0时交换数据可以保证交换后的差值diff一定减小。
代码思路到此为止。
 
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
华为机试真题题库提供了100道算法题,并提供了正确解法和解题思路。这些题目是华为机试真题,大概率会考到原题。如果你有任何问题,可以在题库中留言进行交流和探讨。 华为机试一般有三道算法题,其中前两道属于简单或中等难度,分值为100分。第三道题目为中等或困难难度,分值为200分。总分为400分,答题时间为150分钟。过去通过150分即可,但现在分数要求可能有所提高。不管怎样,大家都要努力刷题,争取拿高分。分数越高,评级就越高,工资待遇也越高。一般工资待遇是15K~30K*14~16,非常可观。 此外,如果你对华为机试真题感兴趣,我还邀请你一同入驻我的博客。我的博客即将同步至腾讯云开发者社区,你可以在那里找到更多的资源和信息。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [华为OD机试真题2022(JavaScript)](https://blog.csdn.net/weixin_40767375/article/details/125276961)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [2023年华为笔试面试机考真题100道(C/C++语言)](https://blog.csdn.net/weixin_38815609/article/details/125658519)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值