菜鸡第一次打icpc

记录一下历程

 习惯#define int long long

 以下皆是按照我认为的难易顺序排序

 K.

  看题意大概就是说求从L加到R

1     ios::sync_with_stdio(false);
2 cin.tie(nullptr);
3 cout.tie(nullptr);
4 int a,b;
5 cin>>a>>b;
6
7 if(a < b) swap(a,b);
8 int res =a-b+1;
9 cout<<(a+b)*res/2;

 B.

  贪心,同一列1多就构造1,否则就构造0

 1 const int N = 1e3 + 10;
2 char s[N][N];
3 char res[N];
4
5 void solve() {
6 ios::sync_with_stdio(false);
7 cin.tie(nullptr);
8 cout.tie(nullptr);
9
10 int n, m;
11 cin >> n >> m;
12 for (int i = 1; i <= n; ++i) {
13 cin >> (s[i] + 1);
14 }
15 for (int j = 1; j <= m; ++j) {
16 int a = 0, b = 0;
17 for (int i = 1; i <= n; ++i) {
18 if (s[i][j] == '0') b++;
19 else a++;
20 }
21 if (a > b) res[j] = '1';
22 else res[j] = '0';
23 }
24 cout << (res + 1);
25 }

G.

  很裸的一个01背包问题,只不过多了一个背包,变二维了

  (数据范围很坑,比赛的时候就因为数据范围的时候一直爆内存错误,下来了把空间开大了就过了)

 1 const int N = 510;
2 int n, v1, v2;
3 int v[N], w1[N], w2[N];
4 int dp[N][N];
5 void solve() {
6 cin >> n >> v1 >> v2;
7 for (int i = 1; i <= n; ++i) {
8 cin >> v[i] >> w1[i] >> w2[i];
9 }
10 for(int i =1;i <= n;++i)
11 for(int j = 0;j <= v1;++j)
12 for(int k = 0;k <= v2;++k){
13 if(j >= v[i]) dp[j][k] = max(dp[j][k],dp[j-v[i]][k]+w1[i]);
14 if(k >= v[i]) dp[j][k] = max(dp[j][k],dp[j][k-v[i]]+w2[i]);
15 }
16 cout<<dp[v1][v2]<<"\n";
17 }

A.

 可以说是dfs吧,从根节点搜到底,如果碰到节点没有后继,说明食物链+1

 从底层的节点向上更新数据,最后输出根节点的最大价值

 (比赛的时候想复杂了,用层序遍历从底层节点向上更新,虽然总的想法差不多,但是在处理边权的时候需要不断重复的搜边造成时间爆炸

  而且也没什么好的办法优化这种搜边的问题,最后卡在6s了)

const int N = 2e6+10,mod = 32416190071;
int n;
int f[N];
int pre[N];
bool st[N];
int ans = 0;
int e[N],ne[N],h[N],idx,w[N];
void add(int a,int b,int v){
e[idx] = b, w[idx] = v, ne[idx] = h[a], h[a] = idx++;
} void dfs(int root){
if(h[root] == -1){
ans ++;
}
f[root] = pre[root] % mod;
for(int i = h[root];~i;i = ne[i]){
int j = e[i],c = w[i];
dfs(j);
f[root] = (f[root]+f[j]*c)%mod;
} } signed main(){
ios::sync_with_stdio(false);
cin.tie(nullptr);
cout.tie(nullptr);
cin>>n;
memset(h,-1,sizeof (h));
for(int i = 1;i < n;++i){
int a,b,v;
cin>>a>>b>>v;
add(a,b,v);
st[b] = true;
}
int root = 0;
for(int i = 1;i <= n;++i) if(!st[i]){
root = i;
break;
}
for(int i =1;i <= n;++i){
cin>>pre[i];
}
dfs(root);
cout<<ans<<"\n"<<f[root]<<"\n";
return 0;
}

菜鸡就只能做到这了,大概总结一下

比较有问题的地方在数据范围和c++输入输出没加速(血泪教训)

别的题感觉数论好多,难受不会

2022icpc新疆省赛的更多相关文章

  1. SCNU ACM 2016新生赛决赛 解题报告

    新生初赛题目.解题思路.参考代码一览 A. 拒绝虐狗 Problem Description CZJ 去排队打饭的时候看到前面有几对情侣秀恩爱,作为单身狗的 CZJ 表示很难受. 现在给出一个字符串代 ...

  2. SCNU ACM 2016新生赛初赛 解题报告

    新生初赛题目.解题思路.参考代码一览 1001. 无聊的日常 Problem Description 两位小朋友小A和小B无聊时玩了个游戏,在限定时间内说出一排数字,那边说出的数大就赢,你的工作是帮他 ...

  3. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  4. SCNU 2015ACM新生赛决赛【F. Oyk闯机关】解题报告

            题目大意:一个$N$$\times$$N$的阵列,每个格子有$X_{ij}$个调和之音,若每次只能选择走右边或下边,从左上角出发走到右下角,问最多能收集到多少个调和之音?       ...

  5. SCNU 2015ACM新生赛初赛【1007. ZLM的扑克牌】解题报告

            题目链接详见SCNU 2015新生网络赛 1007. ZLM的扑克牌 .         其实我在想这题的时候,还想过要不要设置求最小的排列,并且对于回文数字的话,可以把扑克牌折起来( ...

  6. SCNU 2015ACM新生赛初赛【1006. 3D打印】解题报告

            题目链接详见SCNU 2015新生网络赛 1006. 3D打印 .出题思路来自codevs 3288. 积木大赛,属于模拟题.         首先我们把“选择从第L部分到第R部分”理 ...

  7. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  8. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  9. 第七届山东省ACM省赛

    激动人心的省赛终于结束了…平静下来再回头看真的感觉一波三折…先是赛前毫无预兆的查出突发性耳聋…伴随而来的就是左耳听力下降.轻微耳鸣.极个别情况下的头晕…不过这都还好,毕竟药物可以恢复…热身赛只过了一道 ...

随机推荐

  1. 【JDBC】学习路径4-分页查询

    第一章:什么是分页查询呢? 简而言之,分页数 就是百度搜索引擎中的网页的页数. 分页查询,就是从数据库中提取一部分出来,给用户. 用处:减少服务器负担. 为了方便测试,我们先给数据库添加大量信息. 还 ...

  2. 「题解报告」P4577 [FJOI2018]领导集团问题

    题解 P4577 [FJOI2018]领导集团问题 题解区好像没有线段树上又套了二分的做法,于是就有了这片题解. 题目传送门 怀着必 WA 的决心交了两发,一不小心就过了. 题意 求一个树上最长不下降 ...

  3. 校园网跨网段共享文件Samba+SSH

    Introduction This tutorial contains screenshots for the English version of Windows 10. Separate inst ...

  4. Filebeat Nginx Module 自定义字段

    Filebeat Nginx Module 自定义字段 一.修改/usr/local/nginx/conf/nginx.conf中 log_format access '$remote_addr - ...

  5. 云原生之旅 - 2)Docker 容器化你的应用

    前言 上文中我们用Golang写了一个HTTP server,本篇文章我们讲述如何容器化这个应用,为后续部署到kubernetes 做准备. 关键词:Docker, Containerization, ...

  6. Mysqldump 的 的 6 大使用场景的导出命令

    Mysqldump 选项解析 场景描述 1. 导出 db1.db2 两个数据库的所有数据. mysqldump -uroot -p -P8635 -h192.168.0.199 --hex-blob ...

  7. 请求体: Request Body

    官方文档地址:https://fastapi.tiangolo.com/zh/tutorial/body/ # -*- coding: UTF-8 -*- from fastapi import Fa ...

  8. kvm安装windows使用virtio驱动

    Windows安装VirtIO驱动的两种方法 已经使用IDE方式来安装好系统 (1)安装完Windows后,创建一块临时的硬盘和网卡,将其驱动都设置为virtio模式添加到Windows中 (2) 添 ...

  9. 使用nginx代理nexus,不是/根路径

    location /nexus/ { proxy_pass http://192.168.0.218:8081/; proxy_set_header Host $host:$server_port; ...

  10. nsis离开自定义页面保存设置

    这是群里一位朋友问他的自定义页面设置完成后返回上一步无法保存怎么办写的一个小例子,拓展了下,只要不关闭,不管上一步还是进入下一步返回都可以保留原页面设置. !include LogicLib.nsh ...