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
这题不会,贴一下题目等以后有思路了再看看。