csp-j 2022 游记
  fTeIFTEEbS8u 2023年11月02日 35 0
C++

第一题

题目传送门

随便写了写代码如下

#include <bits/stdc++.h>
using namespace std;
string sa;
long long a,b,c=1;
int main(){
    freopen("pow.in","r",stdin);
    freopen("pow.out","w",stdout);
    cin>>sa>>b;
    int len=sa.length();
    if(len>9){
        cout<<-1;
        return 0;
    }
    for(int i=1;i<=len;i++){
        a=a+sa[i-1]-'0';
        if(i!=len) a=a*10;
    }
    if(a>1e9){
        cout<<-1;
        return 0;
    }
    for(int i=1;i<=b;i++){
        if(c*a>1e9){
            cout<<-1;
            return 0;
        }
        c*=a;
    }
    cout<<c;
    return 0;
}

第二题

题目传送门

数学题,当时没想出来,写了个暴力

#include <bits/stdc++.h>
using namespace std;
int k;
long long n,e,d,h;
bool flag;
int main(){
    freopen("decode.in","r",stdin);
    freopen("decode.out","w",stdout);
    cin>>k;
    while(k--){
        cin>>n>>d>>e;
        flag=0;
        h=e*d-1;
        for(int i=1;i<=sqrt(n);i++){
            if(n%i!=0) continue;
            long long p=i,q=n/p;
            if((p-1)*(q-1)==h){
                cout<<p<<" "<<q<<endl;
                flag=1;
                break;
            }
        }
        if(flag==0){
            cout<<"NO"<<endl;
        }
    }
    return 0;
}

第三题

题目传送门

大烦题,90%的时间全花在这了,结果是对的,但对短路的判断没有思路

当时思路

  1. 先将括号内的式子单独拿出计算,将结果返回
  2. 计算&
  3. 计算|

写了个函数,又臭又长,代码如下

#include <bits/stdc++.h>
using namespace std;
string s;
int a,b;
int suan(string s){
    if(s.length()==3){
        if(s[1]=='&'){
            if(s[0]=='0'){
                a++;
                return 0;
            }else return (s[0]-'0')&(s[2]-'0');
        }else{
            if(s[0]=='1'){
                b++;
                return 1;
            }else{
                return (s[0]-'0')|(s[2]-'0');
            }
        }
    }
    int ff=0;
    stringstream sa;
    string aa;
    int last;
    for(int i=0;i<s.length();i++){
        if(s[i]=='('&&ff==0) last=i;
        if(s[i]=='(') ff++;
        else if(s[i]==')'){
            ff--;
            if(ff==0){
                stringstream c;
                for(int j=last+1;j<i;j++){
                    c<<s[j];
                }
                string sc;
                c>>sc;
                sa<<suan(sc);
            }
        }else if(ff==0){
            sa<<s[i];
        }
    }
    sa>>aa;
    sa.clear();
    ff=-1;
    for(int i=0;i<aa.length();i++){
        if(aa[i]=='|'){
            if(aa[i-1]!='&') sa<<aa[i-1]<<aa[i];
            else sa<<aa[i];
        }
        if(aa[i]=='&'){
            stringstream c;
            if(ff==-1){
                c<<aa[i-1]<<aa[i]<<aa[i+1];
            }else{
                c<<ff<<aa[i]<<aa[i+1];
            }
            string sc;
            c>>sc;
            // sa<<suan(sc);
            if(aa[i+2]=='&'){
                ff=suan(sc);
            }else{
                ff=-1;
                sa<<suan(sc);
            }
        }
    }
    sa>>aa;
    sa.clear();
    ff=-1;
    for(int i=0;i<aa.length();i++){
        if(aa[i]=='|'){
            stringstream c;
            if(ff==-1){
                c<<aa[i-1]<<aa[i]<<aa[i+1];
            }else{
                c<<ff<<aa[i]<<aa[i+1];
            }
            string sc;
            c>>sc;
            // sa<<suan(sc);
            if(aa[i+2]=='|'){
                ff=suan(sc);
            }else{
                ff=-1;
                sa<<suan(sc);
            }
        }
    }
    sa>>aa;
    if(aa[0]=='0'){
        return 0;
    }else{
        return 1;
    }
    return 0;
}
int main(){
    freopen("expr.in","r",stdin);
    freopen("expr.out","w",stdout);
    cin>>s;
    cout<<suan(s)<<endl;
    cout<<a<<" "<<b;
    return 0;
}

第四题

题目传送门

没时间写了,就属于有点脑残

大总结

我炸了

问题

  • 时间分配有问题
  • 对数学题没有清晰判断

解决方法

  • 先读一遍所有题,又较清晰的理解后再开始写
  • 注意时间分配

分数

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  8Tw5Riv1mGFK   2024年05月01日   80   0   0 C++
  BYaHC1OPAeY4   2024年05月08日   58   0   0 C++
  yZdUbUDB8h5t   2024年05月05日   44   0   0 C++
  oXKBKZoQY2lx   2024年05月17日   59   0   0 C++
fTeIFTEEbS8u
作者其他文章 更多

2023-11-02