2022年华东师范大学 复试机试

比赛两个小时,为OI赛制(可以暴力拿部分分),一共六道题目。以下仅为本人练习记录,算法不是最优的。

A 整数排序

单点时限:2.0 sec

内存限制:512MB

代码:

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int CountWeishu(int x){//计算位数
    int Weishu=1;
    while(x/10!=0){
        x=x/10;
        Weishu++;
    }
    return Weishu;
}

bool compare(int x,int y){//比较函数
    if(CountWeishu(x)== CountWeishu(y))
        return x<y;
    else
        return CountWeishu(x)>CountWeishu(y);
}

int main() {
    vector<int> arr;
    int n;
    while(cin>>n){
        arr.push_back(n);
        if(getchar()=='\n')//遇到换行符表示输入结束
            break;
    }
    sort(arr.begin(),arr.end(),compare);
    for(int i=0;i<arr.size();i++)
        cout<<arr[i]<<" ";

    return 0;
}

运行结果:

B 位运算

单点时限:2.0 sec

内存限制:512MB

代码:

#include <iostream>
using namespace std;

const int MAXN=32;
int dig[MAXN]={0};//记录二进制数字串

void H10ToH2(int x){//十进制转二进制
    for(int i=0;x!=0;i++){
        dig[i]=x%2;
        x=x/2;
    }
}

int H2ToH10(){//二进制转十进制
    int res=0;
    int i=MAXN-1;
    while(dig[i]==0) i--;
    while(i>=0){
        res=(res+dig[i])*2;
        i--;
    }
    return res/2;
}


int main() {
    int n,m,i,j;
    cin>>n>>i>>j;
    H10ToH2(n);
    swap(dig[i],dig[j]);//交换二进制串中对应位置元素
    m=H2ToH10();
    cout<<m<<endl;

    return 0;
}

运行结果:

C 差分计数

单点时限:0.5 sec

内存限制:512MB

优化没思路,直接上暴力解法,能得一部分分。

代码:

#include <iostream>
using namespace std;

int main(){
    int n,x;
    cin>>n>>x;
    int arr[n];
    for(int i=0;i<n;i++)
        cin>>arr[i];

    int res=0;
    for(int i=0;i<n;i++)
        for(int j=0;j<n;j++){
            if(arr[i]-arr[j]==x) res++;
        }
    cout<<res<<endl;
    return 0;
}

运行结果:

D 罗马数字

单点时限:2 sec

内存限制:512MB

代码:

#include <iostream>
#include <map>
using namespace std;

int main(){
    map<int,string> rule;//定义转换规则
    rule[0]="";
    rule[1]="I",rule[2]="II",rule[3]="III",rule[4]="IV",rule[5]="V";
    rule[6]="VI",rule[7]="VII",rule[8]="VIII",rule[9]="IX",rule[10]="X";
    rule[20]="XX",rule[30]="XXX",rule[40]="XL",rule[50]="L";
    rule[60]="LX",rule[70]="LXX",rule[80]="LXXX",rule[90]="XC",rule[100]="C";
    rule[200]="CC",rule[300]="CCC",rule[400]="CD",rule[500]="D";
    rule[600]="DC",rule[700]="DCC",rule[800]="DCCC",rule[900]="CM",rule[1000]="M";

    int n;
    cin>>n;

    string str[4];//将十进制数字按位拆分,对应相应的罗马数字
    str[3]=rule[n/1000*1000],n=n%1000;
    str[2]=rule[n/100*100],n=n%100;
    str[1]=rule[n/10*10],n=n%10;
    str[0]=rule[n];

    string res=str[3]+str[2]+str[1]+str[0];//拼接各位的罗马数字
    cout<<res<<endl;

    return 0;
}

运行结果:

E 乘法

单点时限:1.0 sec

内存限制:256MB

优化还是没思路,直接上暴力得一部分分吧。

代码:

#include <iostream>
#include <algorithm>
using namespace std;

bool compare(int x,int y){
    return x>y;
}

int main(){
    int n,m,k;
    cin>>n>>m>>k;
    int a[n],b[m];
    for(int i=0;i<n;i++) cin>>a[i];
    for(int i=0;i<m;i++) cin>>b[i];

    int res[n*m];
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++)
            res[i*m+j]=a[i]*b[j];

    sort(res,res+n*m,compare);
    cout<<res[k-1]<<endl;
    return 0;
}

运行结果:

F Minimum Sum

单点时限:2.0 sec

内存限制:256MB

这题不会,贴一下题目等以后有思路了再看看。

说明

本文部分内容转载自:https://blog.csdn.net/qq_35577488/article/details/125224818?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522167711488816800182148967%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=167711488816800182148967&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduend~default-1-125224818-null-null.142^v73^insert_down1,201^v4^add_ask,239^v2^insert_chatgpt&utm_term=%E5%8D%8E%E4%B8%9C%E5%B8%88%E8%8C%83%E5%A4%A7%E5%AD%A6%E5%A4%8D%E8%AF%95&spm=1018.2226.3001.4187

全部评论
E可以二分第K大的值,枚举i,判断有多少个j满足a[j]>MaxK/a[i],在用单调队列优化一下判断个数,能nlogmax实现
点赞 回复 分享
发布于 2023-02-27 22:18 湖北

相关推荐

评论
2
15
分享

创作者周榜

更多
牛客网
牛客企业服务