预推免机试复习

Posted 中二病没有蛀牙

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了预推免机试复习相关的知识,希望对你有一定的参考价值。

https://acm.ecnu.edu.cn/contest/20/

A不等式

B
https://acm.ecnu.edu.cn/problem/3303/

https://acm.ecnu.edu.cn/contest/31/

预推免

https://acm.ecnu.edu.cn/contest/31/problem/A/
A. 吉吉木的野望

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;

int main()
{
    ll d,k;
    cin>>d>>k;
    double sum = 0;
    ll an,sn;
    int cnt = 0;
    for(ll i = min(k,ll(1e7)) ;i >= 1;i--){
        an = 1 + d * (i - 1);
        // cout<<an<<endl;
        if(sum == 0) 
            sum = an;
        else
            sum = an + 1.0/sum;
        cnt++;
    }
    sum =1.0/sum;
    printf("%.16lf\\n",sum);
    return 0;
}

B. 皇后问题

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 1e5+5;

ll visx[maxn];
ll visy[maxn];

ll k1[3*maxn],k2[3*maxn];
int main()
{
    ll n,x,y;
    ll cnt = 0;
    cin>>n;
    while(n--){
        cin>>x>>y;
        if(visx[x] != 0)
            cnt += visx[x];
        if(visy[y] != 0) 
            cnt += visy[y];    
        visx[x]++;
        visy[y]++;
        if(k1[y - x + maxn] != 0)
            cnt += k1[y-x + maxn];
        if(k2[x + y + maxn] != 0)
            cnt += k2[x+y +maxn];
        k1[y - x + maxn]++;
        k2[x + y + maxn]++;

    }
    cout<<cnt<<endl;
    return 0;
}

C

过90%代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 1e5+5;
set<ll> vis;


ll slove(ll s){
    ll ans = 1;
    ll cnt = 0;
    ll x = s;
    for( ll i = 2; i <= sqrt(s);i++){    
        while(x % i == 0){
            x /=  i;
            cnt++;
        }
        ans = ans*(cnt + 1);
        cnt = 0;
    } 
    if(x != 1) ans *= 2; 
    return ans;
}



int main()
{
    ll q,n;
    cin>>q>>n;
    ll sum = 0;
    if(q == 1){
        sum = slove(n);
    }
    else{
        for(ll a = 1 ;a  < n; a++){
            vis.clear();
            ll cnt = 0;
            for (ll x = 1; x <= (n - 1)/ a;x++ ){
                ll by = n - a*x;
                for( ll i = 1 ;i<= sqrt(by);i++){
                    if(by % i ==0){
                        if(vis.find(i) == vis.end()){
                            cnt++;
                            // cout<<a << " "<<i<<endl;
                        }
                        vis.insert(i);
                        if(vis.find(by/i) == vis.end()){
                            cnt++;
                            // cout<<a << " "<<by/i<<endl;
                        }
                        vis.insert(by/i);
                        // vis[by /i] = 1;
                    }
                }
            }
            sum += cnt;
        }
    }
    cout<<sum<<endl;
    return 0;
}

D. 我认识你
超时代码1:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 4e4+5;
vector<int> g[maxn];
set<int> vis;

int main()
{
    int n,m,u,v,q,s,t;
    cin>>n>>m;
    while(m--){
        cin>>u>>v;
        g[u].push_back(v);
        g[v].push_back(u);
    }   
    cin>>q;
    while(q--){
        cin>>s>>t;
        vis.clear();
        int cnt = 0;
        for(auto c:g[s]){
            vis.insert(c);
        }
        for(auto c:g[t]){
            if(vis.find(c) != vis.end()) cnt++;
            vis.insert(c);
        }
        cout<<cnt<<endl;
    }
    return 0;
}

超时代码2:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 4e4+5;
map<int, set<int> > g;


int main()
{
    int n,m,u,v,q,s,t;
    cin>>n>>m;
    while(m--){
        cin>>u>>v;
        g[u].insert(v);
        g[v].insert(u);
    }   
    cin>>q;
    while(q--){
        cin>>s>>t;
        int cnt = 0;
        set<int>::iterator it1 = g[s].begin();
        set<int>::iterator it2 = g[t].begin();
        // cout<<*it1<<endl;
        while (it1 != g[s].end() && it2 != g[t].end()) 
        {
            if( *it1 < *it2)
                it1++;
            else if( *it1 == *it2){
                it1++;
                it2++;
                cnt++;
            }
            else
                it2++;
        }
        cout<<cnt<<endl;
        // cnt = g[s].size() + g[t].size() - cnt;
        // cout<<cnt<<endl;
    }
    return 0;
}

正解:
用bitset二进制压缩优化
bitset类型在定义时就需要指定所占的空间,例如bitset<233>bit;
bitset类型可以用string和整数初始化(整数转化成对应的二进制)

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 4e4+5;
bitset<maxn> g[maxn];

int main()
{
    int n,m,u,v,q,s,t;
    cin>>n>>m;
    while(m--){
        cin>>u>>v;
        g[u][v] = 1;
        g[v][u] = 1;
    }   
    cin>>q;
    while(q--){
        cin>>s>>t;
        int cnt = 0;
        bitset <maxn> tmp = (g[s] & g[t]);
        cnt = tmp.count();
        cout<<cnt<<endl;
    }
    return 0;
}

以上是关于预推免机试复习的主要内容,如果未能解决你的问题,请参考以下文章

2021年浙软夏令营预推免面经

保研流程记录

讲讲你的推免经历,准备预推免的关键要点都有哪些?

哈工大控制预推免通过率多少

保研面试数据结构问题夏令营预推免

保研——夏令营预推免全过程经验贴