2018美团点评内推笔试编程题1

思路:对于题目给定的数组,我们求数组的累加和数组sum,然后对于累加和数组sum中的任一个元素sum[i],

j分别取0到i-1,当sum[i]-sum[j]是k的倍数时,i-j就是以以第j个元素结尾的长度最长的子串的长度。

因此,我们只要遍历i就能求出k倍数的最长子串的长度。

代码:

  1. import java.util.Scanner;  
  2.   
  3. public class Main {  
  4.   
  5.     public static void main(String[] args) {  
  6.         Scanner in = new Scanner(System.in);  
  7.         while (in.hasNext()) {  
  8.             int n = in.nextInt();  
  9.             in.nextLine();  
  10.             long[] sum = new long[n+1];  
  11.             sum[0] = 0;                                 //注意:添加第一个元素为0,方便后续计算。  
  12.             for(int i=0;i<n;i++){              
  13.                 sum[i+1] = sum[i]+in.nextLong();        //累加和数组  
  14.             }  
  15.             in.nextLine();  
  16.             int k = in.nextInt();  
  17.             int maxLen = 0;  
  18.             for(int i=n;i>=1;i--){                     //i从n开始循环  
  19.                 for(int j=0;j<i;j++){  
  20.                     if((sum[i]-sum[j])%k == 0){  
  21.                         maxLen = Math.max(maxLen, i-j);  
  22.                         break;  
  23.                     }  
  24.                 }  
  25.                 if(maxLen >= i-1)                   //当剩下的长度小于等于当前计算出来的最大长度时,停止循环  
  26.                     break;  
  27.             }  
  28.             System.out.println(maxLen);  
  29.         }  
  30.     }  
  31. }  

这个题不难,但是刚开始的时候只能AC 75%,所以做了一点小小的优化,

就是我们需要从累加和数组的最后一个元素开始循环,当剩下的长度小于等于当前计算出来的最大长度时,停止循环。

我们举个简单的例子:数组为 1,2,3,4,5.  k=5.

累加和数组为:1,3,6,10,15

我们从最后一个元素15开始循环,因为15是5的倍数,所以当前最长的长度为5,并且此时可以直接结束循环,因为剩下的子串最长都只能为4,所以不需要再计算了。

另外就是注意一点,累加和数组长度为n+1,第一个 元素要设置为0.



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值