西安邮电第五届校赛

A.拯救咕咕咕之史莱姆
链接:https://ac.nowcoder.com/acm/contest/5678/A
可以算出来史莱姆每天减的血量
第一天:3
第二天:6
第三天:9
第四天:12
第五天:18
第六天:27
总和为:75
因此当血量<= 75 就会求饶

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

int main()
{
    ll n;
    while(cin >> n, n) {
        if(n <= 75) puts("AOLIGEI!");
        else puts("DAAAAAMN!");
    }
    return 0;
 } 

校车
链接:https://ac.nowcoder.com/acm/contest/5678/G
离散差分

#include<bits/stdc++.h>
using namespace std;
typedef pair<int, int> pii;
const int N = 100010;

vector<pii> segs;
vector<int> alls;
int a[N];

unordered_set<int> much;

int T, query;

void insert(int l, int r) {
    a[l] += 1;
    a[r] -= 1;
}

int main()
{
    scanf("%d", &T);
    while(T--) {
        scanf("%d", &query);
        while(query--) {
            int x, y;
            scanf("%d%d", &x, &y);
            segs.push_back({x, y});
            alls.push_back(x);
            alls.push_back(y);
            if(!much.count(x)) much.insert(x);
            if(!much.count(y)) much.insert(y);
        }
        sort(alls.begin(), alls.end());
        alls.erase(unique(alls.begin(), alls.end()), alls.end());
        for(auto seg : segs) {
            int x = lower_bound(alls.begin(), alls.end(), seg.first) - alls.begin() + 1;
            int y = lower_bound(alls.begin(), alls.end(), seg.second) - alls.begin() + 1;
            insert(x, y);    
        }
        for(int i = 1; i <= alls.size(); i++) a[i] += a[i - 1];
        sort(a + 1, a + 1 + alls.size());
        printf("%d %d\n", much.size(), a[alls.size()]);
        much.clear();
        segs.clear();
        memset(a, 0, sizeof a);
    }
    return 0;
}

无敌阿姨
链接:https://ac.nowcoder.com/acm/contest/5678/E

#include<bits/stdc++.h>
using namespace std;
const int N = 105;

int a[N];

int main()
{
    int T;
    scanf("%d", &T);
    while(T--) {
        int n, m, k;
        int sum = 0;
        scanf("%d%d%d", &n, &m, &k);
        for(int i = 1; i <= n; i++) {
            scanf("%d", &a[i]);
            sum += a[i];
        }
        int ans = 0, res;
        int now = 0;
        while(now < sum) {
            ans++;
            res = m;
            for(int i = 1; i <= n; i++) {
                if(a[i]) {
                    while(a[i] && res) {
                        a[i]--;
                        res--;
                        now++;
                    }
                    if(res <= k) 
                        break;
                    res -= k;
                }
            }
        }
        printf("%d\n", ans);
    }
    return 0;
}

烦人的依赖
链接:https://ac.nowcoder.com/acm/contest/5678/B
软件之间的依赖关系看成又向无环图,题目要按字典序排因此要用优先队列小根堆进行存储。

#include<bits/stdc++.h>
using namespace std;
const int N =  30010;

int T, n, m, cnt, an;
string s, t;
string soft[N];
int in[N];       //入度数 
vector<int> edge[N];
priority_queue<int, vector<int>, greater<int> > heap;   //由于当软件等级一样时按照字典序从小到大排, 因此用小根堆      
int ans[N];
unordered_map<string, int> mp;     //需要将软件映射成数字才能进行连边 

void init() {      //由于多组数据进行输入 要对整体进行初始化 
    memset(in, 0, sizeof in);  //度数初始化 
    while(!heap.empty()) //堆的初始化 
        heap.pop();
    for(int i = 1; i <= n; i++)  //对边的初始化 
        edge[i].clear();
    mp.clear(); //映射初始化 
    cnt = 0;  //topsort 的点数 
}

void solve() {
    scanf("%d%d", &n, &m);
    init();
    for(int i = 1; i <= n; i++)
        cin >> soft[i];
    sort(soft + 1, soft + 1 + n);  //从小到大排序 
    for(int i = 1; i <= n; i++)   //进行赋值 
        mp[soft[i]] = i;
    for(int i = 1; i <= m; i++) {
        cin >> s >> t;
        ++in[mp[t]]; //入度++ 
        edge[mp[s]].push_back(mp[t]); //连边 
    }
    for(int i = 1; i <= n; i++) //将入度为0的存入堆中 
        if(!in[i]) heap.push(i);
    while(!heap.empty()) {
        int t = heap.top();
        heap.pop();
        ans[++cnt] = t; //用来存最终的答案 
        for(auto v : edge[t]) { //遍历边 
            if(!(--in[v])) heap.push(v);  //入度为0存入队列 
        }
    }
    printf("Case #%d:\n", ++an);
    if(cnt != n) {         //若点数不服则不存在 
        printf("Impossible\n");
        return ;
    }
    for(int i = 1; i <= cnt; i++)
        cout << soft[ans[i]] << endl;
}

int main()
{
    scanf("%d", &T);
    while(T--) {
        solve();
    }
    return 0;
}

异或生成树
dp[i][j]表示以i为节点能异或出来的值, 1表示能够组成出来,0表示不能够组成出来
由于是异或因此范围是0-127
状态转移方程为dp[u][i ^ j] = dp[u][i] & dp[v][j];
代码如下

#include<bits/stdc++.h>
using namespace std;
const int N = 105, M = 1 << 7;

int n;
vector<int> G[N];
int ans = 0, a[N], dp[N][M], tmp[M];

void dfs(int u, int f) {
    dp[u][a[u]] = 1;       //由于u存在这样的点a[u] 因此赋值为1 
    for(auto v : G[u]) {
        if(v != f) {
            dfs(v, u);
            memset(tmp, 0, sizeof tmp);    //将其初始化为0,让tmp 和 dp 去或(|) 判断这样的点是否存在 
            for(int i = 0; i < 128; i++) {
                for(int j = 0; j < 128; j++)            //u 为父节点 v 为子节点 若存在 &上为1 tmp|上为1 
                    tmp[i ^ j] |= dp[u][i] & dp[v][j]; //这一步求出父节点和子节点的异或的值有哪些  
            }
            for(int i = 0; i < 128; i++) //对dp的值进行更新 
                dp[u][i] |= tmp[i];
        }
    }
    for(int i = 0; i < 128; i++) 
        if(dp[u][i])
            ans = max(ans, i);    //找到最大值 
}

int main()
{
    scanf("%d", &n);
    for(int i = 1; i <= n; i++)
        scanf("%d", &a[i]);
    for(int i = 1; i < n; i++) {
        int x, y;
        scanf("%d%d", &x, &y);
        G[x].push_back(y);
        G[y].push_back(x);
    }
    dfs(1, -1);
    printf("%d", ans);
    return 0;
}
全部评论

相关推荐

shanhai1:第一份实习挺看运气的
点赞 评论 收藏
分享
从大一开始就开始学习Java,一路走来真的不算容易,每次面试都被压力,不过这次终于达成了自己的一大心愿!时间线和面经:8.17-投递9.1-一面实习+项目拷打看门狗机制讲一下redis加锁解锁的本身操作是什么Lua脚本是干什么的udp和tcp讲一下流量控制讲一下令牌桶算法说一下大端和小端是什么线程和协程有什么区别怎么切换协程切换的时候具体做了什么对于程序来说,你刚才提到的保存和恢复现场,这个现场有哪些信息udp优势现在有一个客户端和服务端,要实现TCP的通信,我们的代码要怎么写服务器怎么感知有新的连接怎么处理多个客户端的请求连接TCP怎么处理粘包和分包现在有两个文件,然后每个文件都有一亿条URL,每个的长度都很长,要怎么快速查找这两个文件共有的URLHashmap底层说一下怎么尽量提升插入和查询的效率如果要查找快,查询快,还有解决非空的问题,怎么做LoadingCache了解吗手撕:堆排序9.4-二面部门的leader,超级压力面拷打实习+项目,被喷完全没东西类的加载到垃圾回收整个底层原理讲一遍类加载谁来执行类加载器是什么东西,和进程的关系Java虚拟机是什么东西,和进程的关系如果我们要执行hello&nbsp;world,那虚拟机干了什么呢谁把字节码翻译成机器码,操作时机是什么Java虚拟机是一个执行单元吗Java虚拟机和操作系统的关系到底什么,假如我是个完全不懂技术的人,举例说明让我明白一个操作系统有两个Java程序的话,有几个虚拟机有没有单独的JVM进程存在启动一个hello&nbsp;world编译的时候,有几个进程JVM什么时候启动比如执行一条Java命令的时候对应一个进程,然后这个JVM虚拟机到底是不是在这个进程里面,还是说要先启动一个JVM虚拟机的进程垃圾回收机制的时机能手动触发垃圾回收吗垃圾回收会抢占业务代码的CPU吗垃圾回收算法简单说说垃圾回收机制的stop&nbsp;the&nbsp;world存在于哪些时机垃圾回收中的计算Region的时候怎么和业务代码并行执行假如只有一个线程,怎么实现并行Java为什么要这么实现Java效率比C++慢很多,那为什么还要这样实现Java虚拟机到底是什么形式存在的说一下Java和C++的区别还有你对Java设计理念的理解无手撕面试结束的时候,我真的汗流浃背了,面试官还和我道歉,说他是故意压力面想看看我的反应的,还对我给予了高度评价:我当面试官这么多年,你是我见过最好的一个9.9-三面临时通知的加面,就问了三十分钟项目9.11-hr面问过往经历,未来计划,想从腾讯实习中得到什么?当场告知leader十分满意我,所以直接ochr面完一分钟官网流程变成录用评估中,30分钟后mt加微信告知offer正在审批9.15-offer这一次腾讯面试体验真的不错,每个面试官能感觉到专业能力很强,反馈很足,比起隔壁某节真是好太多以后就是鹅孝子了
三本咋了:当面试官这么多年你是我见过的最好的一个
你面试被问到过哪些不会的...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务