大家笔试做的怎么样!

我快速做完第一题后,被二三题的内存超限弄得怀疑人生。。直接不看第四题提前交卷了。
顺便求大佬看看我的代码究竟哪里错了。。

第二题:(内存超限)
思路:找出最矮的楼,ans=最矮的楼高度×楼的数量,然后以最矮的楼为界分出左右两块,然后在新的数组里面接着找最矮的楼,ans=最矮的楼高度×楼的数量,找出最大的ans。
#include<bits/stdc++.h>
using namespace std;
vector<int> s;
void back(int& ans ,int l,int r){
    if(r-l<=1) return ;
    int len=r-l+1,min=10000,flag;
    for(int i=l;i<l+len;++i){
        if(min>s[i]){
            min=s[i];
            flag=i;
        }
    }
    if(min*len>ans) ans=min*len;
    if(flag==l) return ;
    back(ans,l,flag-1);
    back(ans,flag+1,r);
    return ;
}
int main(){
    int n,h;
    cin>>n;
    //vector<int> v(n);
    int min=10000;
    for(int i=0;i<n;++i){
        cin>>h;
        s.push_back(h);
        if(h<min){
            min=h;
        }
    }
    int ans=min*n;
    back(ans,0,n-1);
    cout<<ans;
}

第三题(样例通过,但输出0%):
思路:一位位加上去,每加一位数字就判断三个条件是否满足。
#include<bits/stdc++.h>
using namespace std;

void back(const int &n,const int &s,const int &x,int r,int add,int num,int&count){
    if(r>=n || add>=s) {
        if(add==s && r==n) count=(count+1)%1000009;
        return;
    }
    for(int i=0;i<10;++i){
        int temp=num;
        if(num>99) num=num%100;
        num=num*10+i;
        if(num%x==0 || r<3) {
            ++r;
            add+=i;
            back(n,s,x,r,add,num,count);
            add-=i;
            --r;
        }
        else num=temp;
    }
    return;
}

int main(){
    int n,s,x;
    cin>>n>>s>>x;
    int count=0;
    back(n,s,x,0,0,0,count);
    cout<<count+1;
}


#雷火笔试##投票##网易雷火#
全部评论
第三题感觉麻烦没做,写第四题给我写吐了,最后才理清关系没时间改代码了
点赞 回复 分享
发布于 2020-04-25 16:59
第三题用回溯过了10%,......第四题读了一遍,发现出题人瞎出题, 很多歧义, 放弃了.
点赞 回复 分享
发布于 2020-04-25 17:01

相关推荐

牛客604067584号:我9月初投递10月入池,泡到现在。hr全部离职,当然没离职的时候也联系不上。我发邮件给campus也不回我
点赞 评论 收藏
分享
01-14 15:08
东南大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务