阿里p7阿里健康2面20201218笔试算法(指针操作)

/*
   两个正序排序的数组,求合并后的第K个。两个数组内元素没有 0,找不到第 K 个数可以返回 0。

   示例 1:
   如果 K = 5
   >array1 = [1, 13, 16, 20]
   >array2 = [2, 8, 12, 27]
   >则第K个数是:13

   ====================================注意=========================================
   ====================================注意=========================================
   要求:
   1、不要申请额外的空间,比如:数组、List、Set、Map;变量定义的是可以;
   2、不要使用java的sort相关函数,当然也不要自己手写冒泡排序,本题不是考察排序算法;
   3、需要写单元测试,写在独立文件中,或写在本类main方法里;
   4、穷举想到的测试边界case,而不仅仅是题目中示例的case;
*/
public class FindKSolution {

	public int findK(int[] array1, int[] array2, int k) {
		return 0;
	}
}

这道题考点比较多最主要的是对于代码风格和数据边界测试,以及边界定义的划分,主要考点在这里,实现代码:

public class FindKSolution {

    public Integer findK(int[] array1, int[] array2, int k) {
        //1.判断是否处于边界
        if(array1 == null || array2 == null){
            return null;
        }
        if(k<=0){
            return null;
        }
        if(k>array1.length+array2.length){
            return null;
        }
        //2.循环打点取数据判断是第k个值
        int i = 0;
        int j = 0;
        int point = 0;
        Integer value = null;
        while(true){
            //判断i 和 j 不能大于array1,array2 length
            if(i>=array1.length && j>=array2.length ){
                break;
            }
            //获取相对的两个数组的值进行比较
            int a1 = -1;
            if(array1.length !=0&&i<array1.length) {
                a1 = array1[i];
            }
            int a2 =-1;
            if(array2.length !=0&&j<array2.length){
                a2 = array2[j];
            }
            //因为array1,array2是正序的数据,取最小值进行比较
            if((a1<a2 && a1!=-1)||a2<0){
                value = a1;
                i++;
            }else if((a1>=a2 && a2!=-1)||a1<0){
                value = a2;
                j++;
            }else {
                break;
            }
            // 记录第几个数
            point ++;
            //当记录的第几个数等于k 时返回value
            if(point >= k){
                return value;
            }
        }
        return null;
    }

    public static void main(String[] args) {
        FindKSolution findKSolution = new FindKSolution();
        int[] array1 = {1,13,16,20};
        int[] array2 = {2,8,12,27};
        int k= 5;
        Integer data1 = null;
        //预期合并数组  1,2,8,12,13,16,20,27
        data1 = findKSolution.findK(array1,array2,k);
        System.out.println("预期值 13 data:"+data1);
        //边界值8
        k=8;
        data1 = findKSolution.findK(array1,array2,k);
        System.out.println("预期值 27 data:"+data1);
        //边界值0
        k=0;
        data1 = findKSolution.findK(array1,array2,k);
        System.out.println("预期值 null data:"+data1);
        //边界值1
        k=1;
        data1 = findKSolution.findK(array1,array2,k);
        System.out.println("预期值 1 data:"+data1);
        //数组边界值 array1 少  array2 多
        array1 = new int[]{1, 13, 16, 20};
        array2 = new int[]{2};
        k=2;
        data1 = findKSolution.findK(array1,array2,k);
        System.out.println("预期值 2 data:"+data1);
        //1,2,13,16,20,
        k = 3;
        data1 = findKSolution.findK(array1,array2,k);
        System.out.println("预期值 13 data:"+data1);
        //数组边界值 array1 一边值小
        array1 = new int[]{1, 13, 16, 20};
        array2 = new int[]{21};
        k = 3;
        data1 = findKSolution.findK(array1,array2,k);
        System.out.println("预期值 16 data:"+data1);
    }
}

输出结果:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
阿里巴巴是中国最大的电子商务公司之一,拥有众多的技术岗位,其中包括Java开发工程师。作为P7级别的Java试,通常会涉及以下几个方的内容: 1. Java基础知识:包括Java语言的特性、向对象编程、集合框架、多线程、IO操作等。试官可能会深入询问Java的内存模型、垃圾回收机制等底层知识。 2. 数据结构与算法试官可能会考察你对常用数据结构(如数组、链表、栈、队列、树等)的理解和应用,以及常见算法(如排序、查找、动态规划等)的实现和优化。 3. 分布式系统与微服务架构:阿里巴巴是一个大规模分布式系统的典型代表,试中可能会涉及分布式系统的设计原则、CAP理论、一致性算法等。此外,对于微服务架构的理解和实践经验也是重要的考察点。 4. 高可用与性能优化:试官可能会关注你在高可用性和性能优化方的经验,包括负载均衡、容灾备份、故障恢复、性能监控与调优等。 5. 设计模式与架构思维:试官可能会要求你解释常见的设计模式,并能够在实际场景中应用。此外,对于系统架构的理解和设计能力也是重要的考察点。 6. 开源技术与工程实践:阿里巴巴非常注重开源技术的应用和贡献,试中可能会涉及你对一些开源框架和工具的了解和使用经验,以及你在团队协作、代码质量管理等方的实践经验。 以上是一些可能涉及到的试内容,具体试题目和难度会根据职位要求和试官的个人喜好而有所不同。在准备试时,建议你系统地复习Java基础知识、数据结构与算法,并结合自己的项目经验进行思考和总结。另外,多参加一些模拟试和刷题训练也是提高试技巧和应对能力的有效方式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值