2019.6.20义乌测试赛自我成绩分析

Posted hulean

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2019.6.20义乌测试赛自我成绩分析相关的知识,希望对你有一定的参考价值。

A. 平均分(average)

  • 提交程序:
#include<bits/stdc++.h>
using namespace std;
int n,a;
int sum=0;
inline int read()

    int tot=0,f=1;
    char c=getchar();
    while(c<'0'||c>'9')
    
        if(c=='-')f=-1;
        c=getchar();
    
    while(c>='0'&&c<='9')
    
        tot=(tot<<1)+(tot<<3)+c-'0';
        c=getchar();
    
    return tot*f;

int main()

    n=read();
    for(int i=1;i<=n;i++)
        a=read(),sum+=a;
    cout<<fixed<<setprecision(2)<<(double)sum/(double)n<<endl;
    return 0;
       
  • 评测结果:

Accepted 100分

  • 错误原因

  • 正确代码


B.非降(nodown)

  • 提交程序:
#include<bits/stdc++.h>
using namespace std;
char s[1000];
int n;
int main()

    scanf("%s",s+1);
    n=strlen(s+1);
    for(int i=2;i<=n;i++)
    
        if(s[i]<s[i-1])
        
            cout<<"No\n";
            return 0;
        
    
    cout<<"Yes\n";
    return 0;
  • 评测结果:

Accepted 100分

  • 错误原因

  • 正确代码


C.新魔法(new)

  • 提交程序:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int MAXN=100000+10;
int n,k;
ll a[MAXN];
ll g[MAXN];
ll ans=0;
inline int read()

    int tot=0,f=1;
    char c=getchar();
    while(c<'0'||c>'9')
    
        if(c=='-')f=-1;
        c=getchar();
    
    while(c>='0'&&c<='9')
    
        tot=(tot<<1)+(tot<<3)+c-'0';
        c=getchar();
    
    return tot*f;

int main()

    n=read();k=read();
    for(int i=1;i<=n;i++)
    
        a[i]=read();
        a[i]*=1000;
        g[i]=g[i-1]+a[i];
        //cout<<g[i]<<endl;
    
    for(int i=k;i<=n;i++)
    
        ans=max(ans,(g[i]-g[i-k])/k);
    
    cout<<ans<<endl;
    return 0;
  • 评测结果:

Accepted 100分

  • 错误原因

  • 正确代码


D.排名(sort)

  • 提交程序:
#include<bits/stdc++.h>
using namespace std;
const int MAXN=3000+10;
int n;
struct Node

    int sum;
    int s;
a[MAXN];
inline int read()

    int tot=0,f=1;
    char c=getchar();
    while(c<'0'||c>'9')
    
        if(c=='-')f=-1;
        c=getchar();
    
    while(c>='0'&&c<='9')
    
        tot=(tot<<1)+(tot<<3)+c-'0';
        c=getchar();
    
    return tot*f;

inline int get(int x)

    int tot=0;
    while(x)
    
        tot+=x%10;
        x/=10;
    
    return tot;

inline bool cmp(Node x,Node y)

    if(x.sum==y.sum)return x.s>y.s;
    else return x.sum>y.sum;

int main()

    n=read();
    for(int i=1;i<=n;i++)
    
        a[i].s=read();
        a[i].sum=get(a[i].s);
        //cout<<a[i].s<<" "<<a[i].sum<<endl;
    
    sort(a+1,a+1+n,cmp);
    for(int i=1;i<=n;i++)
        printf("%d\n",a[i].s);
    return 0;
 
  • 评测结果:

Accepted 100分

  • 错误原因

  • 正确代码


E.宿舍改建(build)

  • 提交程序:
#include<bits/stdc++.h>
using namespace std;
const int MAXN=10000+10;
int n,m,a;
int w[MAXN];
int cnt=0;
inline int read()

    int tot=0,f=1;
    char c=getchar();
    while(c<'0'||c>'9')
    
        if(c=='-')f=-1;
        c=getchar();
    
    while(c>='0'&&c<='9')
    
        tot=(tot<<1)+(tot<<3)+c-'0';
        c=getchar();
    
    return tot*f;

int main()

    n=read();m=read();
    for(int i=1;i<=n;i++)
    
        a=read();
        int pos=1;
        while(pos<=cnt&&w[pos]+a>m)pos++;
        if(pos>cnt)w[++cnt]=a;
        else
        
            w[pos]+=a;
        
    
    cout<<cnt<<endl;
    return 0;
       
  • 评测结果:

Unaccepted 40分

  • 错误原因
由于之前去华东吃饭大学参加了“游族杯”的比赛,其中有一题和这题非常非常非常相似,简直就是翻版(然而其实本质上是不一样的)。
于是我就被洗脑了,一时没想到这题其实时一道很简单的二分题,而是用了一种奇奇怪怪的贪心来做
  • 正确代码
#include<bits/stdc++.h>
using namespace std;
const int MAXN=10000+10;
int n,m;
int a[MAXN];
int tt[MAXN];
inline int read()

    int tot=0,f=1;
    char c=getchar();
    while(c<'0'||c>'9')
    
        if(c=='-')f=-1;
        c=getchar();
    
    while(c>='0'&&c<='9')
    
        tot=(tot<<1)+(tot<<3)+c-'0';
        c=getchar();
    
    return tot*f;

inline bool check(int t)

    for(int i=1;i<=t;i++)
        tt[i]=a[i];
    for(int i=t+1;i<=n;i++)
    
        int minn=0x3f3f3f3f,pos=0;
        for(int j=1;j<=t;j++)//这一部分也可以用单调队列优化
            if(tt[j]<minn)minn=tt[j],pos=j;
        tt[pos]+=a[i];
        if(tt[pos]>m)return 0;
    
    return 1;

int main()

    n=read();m=read();
    for(int i=1;i<=n;i++)
        a[i]=read();
    int l=1,r=n,ans;
    while(l<=r)
    
        int mid=l+r>>1;
        //cout<<l<<" "<<r<<" "<<mid<<" "<<check(mid)<<endl;
        if(check(mid))r=mid-1,ans=mid;
        else l=mid+1;
    
    cout<<ans<<endl;
    return 0;

F.争霸赛(game)

  • 提交代码:
#include<bits/stdc++.h>
using namespace std;
const int MAXN=2500+10;
int n,k;
int a[MAXN],b[MAXN];
int cnt=0;
inline int read()

    int tot=0,f=1;
    char c=getchar();
    while(c<'0'||c>'9')
    
        if(c=='-')f=-1;
        c=getchar();
    
    while(c>='0'&&c<='9')
    
        tot=(tot<<1)+(tot<<3)+c-'0';
        c=getchar();
    
    return tot*f;

int main()

    ios::sync_with_stdio(false);
    //freopen("data2.in","r",stdin);
    n=read();k=read();
    char c;
    for(int i=1;i<=n;i++)
    
        a[i]=a[i-1];
        b[i]=b[i-1];
        cin>>c;
        if(c=='H')a[i]++;
        else b[i]++;
        //cout<<a[i]<<" "<<b[i]<<endl;
    
    int pos=n;
    while(a[n]!=0||b[n]!=0)
    
        bool flag=0;
        //Sleep(100);
        if(abs(a[pos]-b[pos])<=k||!a[pos]||!b[pos])
        
            cnt++;
            flag=1;
        
        else pos--;
        if(flag)
        
            int x=a[pos],y=b[pos];
            for(int i=pos;i<=n;i++)
            
                a[i]-=x;
                b[i]-=y;
            
            pos=n;
        
        /*cout<<pos<<" "<<flag<<" "<<cnt<<endl;
        for(int i=1;i<=n;i++)cout<<a[i]<<" "<<b[i]<<endl;
        cout<<endl;*/
    
    cout<<cnt<<endl;
    return 0;
  • 评测结果:

Unaccepted 30分

  • 错误原因:
对于这题的30分,我感到十分恼火与悲哀,看到错误代码了吗?只要我把主函数里的"ios::sync_with_stdio(false)"给去掉,我就可以拿80分的高分!!!
ios::sync_with_stdio(false)是关闭同步输入输出流的意思,在一定条件下可以加快读入数据的速度。
值得一提的是:这个流氓一样的东西还是叶康杰教我们的,但却让我白白丢了50分TAT
把这个东西去掉,还是只能拿80分,并拿不到满分,说明了贪心思想在本题是行不通的,要AC此题必须要进行DP
  • 正确代码:
#include<bits/stdc++.h>
using namespace std;
const int MAXN=2500+10;
int n,k;
int a[MAXN],b[MAXN];
int cnt=0;
int dp[MAXN];
inline int read()

    int tot=0,f=1;
    char c=getchar();
    while(c<'0'||c>'9')
    
        if(c=='-')f=-1;
        c=getchar();
    
    while(c>='0'&&c<='9')
    
        tot=(tot<<1)+(tot<<3)+c-'0';
        c=getchar();
    
    return tot*f;

int main()

    //freopen("data2.in","r",stdin);
    n=read();k=read();
    char c;
    dp[0]=0;
    for(int i=1;i<=n;i++)
    
        a[i]=a[i-1];
        b[i]=b[i-1];
        cin>>c;
        if(c=='H')a[i]++;
        else b[i]++;
        //cout<<a[i]<<" "<<b[i]<<endl;
        dp[i]=i;
    
    for(int i=1;i<=n;i++)
    
        for(int j=1;j<=i;j++)
        
            int x=a[i]-a[j-1],y=b[i]-b[j-1];
            if(abs(x-y)<=k||!x||!y)dp[i]=min(dp[i],dp[j-1]+1);
        
    
    cout<<dp[n]<<endl;
    return 0;

以上是关于2019.6.20义乌测试赛自我成绩分析的主要内容,如果未能解决你的问题,请参考以下文章

2017国赛小结

第十六届全国大学生智能车竞赛百度智慧交通竞赛成绩

2021美赛成绩查询入口和美赛成绩公布时间

蓝桥杯省赛真题10Scratch考试成绩 少儿编程scratch蓝桥杯省赛真题讲解

蓝桥杯省赛真题30Scratch考试成绩录入系统 少儿编程scratch蓝桥杯省赛真题讲解

数据可视化分析2020年美赛MCM/ICM成绩