美团校招-K 的倍数-C++

K 的倍数

时间限制:C/C++语言 2000MS;其他语言 4000MS
内存限制:C/C++语言 65536KB;其他语言 589824KB

题目描述:

序列中任意个连续的元素组成的子序列称为该序列的子串。
现在给你一个序列P和一个整数K,询问元素和是K的倍数的子串的最大长度。
比如序列【1,2,3,4,5】,给定的整数K为 5,其中满足条件的子串为{5}、{2,3}、{1,2,3,4}、{1,2,3,4,5},
那么答案就为 5,因为最长的子串为{1,2,3,4,5};如果满足条件的子串不存在,就输出 0。
输入
第一含一个整数N, 1 ≤ 𝑁 ≤ 105 。
第二行包含 N 个整数𝑝𝑖 ,𝑝𝑖 表示序列P第i个元素的值。0 ≤ 𝑝𝑖 ≤ 105 。
第三行包含一个整数 K, 1 ≤ 𝐾 ≤ 105 。
输出
输出一个整数ANS,表示答案。

样例输入

Input Sample 1
5
1 2 3 4 5
5
Input Sample 2
6
3 1 2 7 7 7
4

样例输出

Output Sample 1
5
Output Sample 2
5

#include <iostream>
using namespace std;
int main(){
   int n,k;
   int a[100000];
   int sum,c,max=0;
   cin>>n;
   for(int i=0;i<n;i++){
        cin>>a[i];
        cin>>k;
   }
   for(int i=0;i<n;i++) {    
       sum=a[i];
       for(int j=i+1;j<n;j++){ 
           sum=a[j]+sum;
           if((sum%k)==0) {
                c=j-i+1;
                if(c>max)
                 max=c;
              }
          }
    
    }
    cout<<max<<endl;
}

67%

解决方法1:

输入上万的题目 用scanf不要用cin

for(int i=0;i<n;i++){
    cin>>a[i];
    cin>>k;
}
vector<int> v; 
int x; 
for (int i=0; i<n; i++) { 
    scanf("%d",&x); 
    v.push_back(x); 
}

解决方法2:

程序加上

if(ans>n-i)//加了这句就不会超时
    break;
#include<iostream>
#include<vector>
#include<string>
using namespace std;
int main()
{
    int n,key;
    while(cin>>n)
    {
        int vec[100000];        
        for(int i=0;i<n;i++)
        {
            cin>>vec[i];
        }
        cin>>key;
        int ans=0;//满足条件的子串的最大长度
        for(int i=0;i<n;i++)
        {
            int sum=0;
            for(int j=i;j<n;j++)
            {
                sum+=vec[j];
                if(sum%key==0)
                {
                    if(j-i+1>ans)
                        ans=j-i+1;
                }
            }
            if(ans>n-i)//加了这句就不会超时
                break;
        }
        cout<<ans<<endl;
    }
    return 0;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,779评论 18 399
  • 最近在写个性化推荐的论文,经常用到Python来处理数据,被pandas和numpy中的数据选取和索引问题绕的比较...
    shuhanrainbow阅读 4,607评论 6 19
  • 树形动态规划,顾名思义就是树+DP,先分别回顾一下基本内容吧:动态规划:问题可以分解成若干相互联系的阶段,在每一个...
    Mr_chong阅读 1,522评论 0 2
  • 【1】7,9,-1,5,( ) A、4;B、2;C、-1;D、-3 分析:选D,7+9=16;9+(-1)=8;(...
    Alex_bingo阅读 19,170评论 1 19
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,009评论 19 139