2018-2019 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2018) - 4.28

 

赛后补了几道

赛中我就写了两个...

A - Altruistic AmphibiansGym - 101933A

看了眼榜没几个人做。就没看。

最后发现就是一个DP(但是我觉得复杂度有点迷)

题意:$n$只青蛙有参数$l,w,h$分别表示弹跳力,体重,身高,在一口深为$d$的井里

一只青蛙不能承受比他重的重量,问最多有多少只能出去(达到高度严格大于d)

重的肯定比轻的晚出去,那么轻的肯定由重的来转移,所以先排序,从重到轻的排

$dp_{i}$表示体重为i最高能叠多高 瞎jb转移一下就好了

#include <cstdio>
#include <algorithm>
#include <cstring>
#define ll long long
using namespace std;inline int read() {int x = 0, f = 1; char ch = getchar();while (ch < '0' || ch > '9') { if (ch == '-') f = -1; ch = getchar(); }while (ch >= '0' && ch <= '9') { x = x * 10 + ch - '0'; ch = getchar(); }return x * f;
}const int N = 1e5 + 10;
const int M = 1e8 + 10;
struct P {int l, w, h;bool operator < (const P &rhs) const {return w > rhs.w;}
} p[N];
int dp[M], n, d, ans;int main() {n = read(), d = read();for (int i = 1; i <= n; i++) p[i].l = read(), p[i].w = read(), p[i].h = read();ans = 0;sort(p + 1, p + n + 1);for (int i = 1; i <= n; i++) {if (dp[p[i].w] + p[i].l > d) ans++;for (int j = p[i].w + 1; j < min(p[i].w * 2, M); j++) {dp[j - p[i].w] = max(dp[j-p[i].w], dp[j] + p[i].h);} }printf("%d\n", ans);return 0;
}
View Code

 

B - Baby Bites Gym - 101933B

#include <cstdio>
#include <cstring>
using namespace std;const int N = 1010;
int a[N];
int n;
char s[N];int main() {scanf("%d", &n);bool ans = true;for (int i = 1; i <= n; i++) {scanf("%s", s);int len = strlen(s);if (s[0] == 'm') a[i] = i;else {int x = 0;for (int j = 0; j < len; j++) x = x * 10 + s[j] - '0';a[i] = x;if (x != i) {ans = false;}}}puts(ans?"makes sense":"something is fishy");return 0;
}
View Code

 

C - Code Cleanups Gym - 101933C

阅读理解题啊。自己瞎糊了一发。读不下去。就丢给队友了。

不管了。

 

E - Explosion Exploit Gym - 101933E

题意:分别有$n,m$个士兵,每个士兵有一个血量,有d个攻击,等概率分给每一个士兵。

问敌方士兵全死(m)的概率是多少

队友过的。学习了新知识,概率记忆化+状压

用一个long long来表示状态

unordered_map来存状态对应的概率 再回溯搜索即可 tql

#include <bits/stdc++.h>
#define ll long long
using namespace std;inline int read() {int x = 0, f = 1; char ch = getchar();while (ch < '0' || ch > '9') { if (ch == '-') f = -1; ch = getchar(); }while (ch >= '0' && ch <= '9') { x = x * 10 + ch - '0'; ch = getchar(); }return x * f;
}unordered_map<ll, double> mp;
int a[2][10];ll getsta() {ll ret = 0;for (int i = 1; i <= 6; i++) ret = ret * 10 + 1LL * a[1][i];for (int i = 1; i <= 6; i++) ret = ret * 10 + 1LL * a[0][i];return ret;
}double dfs(ll sta, int d) {if (mp.count(sta)) return mp[sta];if (sta < 1000000) return 1;if (d == 0) return 0;int sum = 0;for (int i = 0; i < 2; i++) for (int j = 1; j <= 6; j++)sum += a[i][j];double ret = 0;for (int i = 0; i < 2; i++) {for (int j = 1; j <= 6; j++) {if (!a[i][j]) continue;a[i][j]--;a[i][j-1]++;ll s = getsta();double res = dfs(s, d - 1);a[i][j]++;a[i][j-1]--;mp[s] = res;ret += a[i][j] * 1.0 / sum * res;}}return ret;
}int main() {int n = read(), m = read(), d = read();for (int i = 1, x; i <= n; i++) x = read(), a[0][x]++;for (int i = 1, x; i <= m; i++) x = read(), a[1][x]++;double res = dfs(getsta(), d);printf("%.8f\n", res);return 0;
}
View Code

 

H - House Lawn Gym - 101933H

题意:有m台机器,每台机器有名字,价格p,每分钟能工作多少c,充一次电能工作多久t,充电需要多久r

有l面积的地待作,问平均每周能工作一次的机器中价格最小的那个,相同的按输入顺序输出

队友把10080说成10800能忍?

平均一下直接就把充电需要的时间给平均进来 得到每分钟工作多少的p'

再用$l/p'$和10080比就得出答案了

可能难就难在输入部分吧。

#include <bits/stdc++.h>
using namespace std;struct Node
{string name;int p , c, t, r;double cc;
}b[105];
bool vis[105];int main()
{ios::sync_with_stdio(false);int m;int l;cin >> l >> m;string a;getline(cin,a);for(int i=1;i<=m;i++){getline(cin,a);int sta = 0;b[i].name = "";b[i].p = b[i].c = b[i].r = b[i].t = 0;for(int j=0;j<a.length();j++){if(a[j]==','){sta++;continue;}if(sta == 0){b[i].name+=a[j];}if(sta == 1){b[i].p*=10;b[i].p+=a[j]-'0';    }if(sta == 2){b[i].c*=10;b[i].c+=a[j]-'0';    }if(sta == 3){b[i].t*=10;b[i].t+=a[j]-'0';    }if(sta == 4){b[i].r*=10;b[i].r+=a[j]-'0';    }}}int ans = 1e9;for (int i = 1; i <= m; i++) {b[i].cc = (b[i].c * b[i].t) * 1.0 / (b[i].t + b[i].r);if (l / b[i].cc <= 10080) {ans = min(ans, b[i].p);vis[i] = 1;}}if (ans == (int)1e9) puts("no such mower");else {for (int i = 1; i <= m; i++) {if (vis[i] && ans == b[i].p) {cout << b[i].name << '\n';}}    }return 0;
}
View Code

 

J - Jumbled String Gym - 101933J

题意: 0 1串 给你00出现的次数a 01出现的次数b 10出现的次数c 11出现的次数d

问能否构造出01串

WA了好几发 一度崩溃

首先由a d能推出0和1的个数 必定是一个C(n, 2) 把a和d乘二开根 和加一相乘是否等于2a和2d来判断

第二部分

用两个数组表示

$a_{i}$表示第i个0后面出现了几个1

$b_{i}$表示第i个0前面出现了几个1

必定有$a_{i} + b_{i} = cnt_{1}$        $a_{i}\geq a_{i+1}$        $b_{i}\leq b_{i+1}$

$\sum ^{cnt_{0}}_{i=1}a_{i} = b$            $\sum ^{cnt_{0}}_{i=1}b_{i} = c$

所以$b + c = cnt_{0}\times cnt_{1}$才有解

随便举几个例子发现贪心的构造均能满足答案

如样例 3 4 2 1

得到$cnt_{0} = 3$   $cnt_{1} = 2$

$a_{i}$ : 2 2 0

$b_{i}$ : 0 0 2

得到 00110 也符合

所以直接构造就完了

不过要注意

0 0 0 0直接输出0或1就可以了

a为0或d为0的情况 如果$b + c = 0$ 那么对应的0的个数或1的个数为0 否则才为1

然后瞎jb输出就完了

#include <cstdio>
#include <algorithm>
#include <cmath>
using namespace std;inline int read() {int x = 0, f = 1; char ch = getchar();while (ch < '0' || ch > '9') { if (ch == '-') f = -1; ch = getchar();}while (ch >= '0' && ch <= '9') { x = x * 10 + ch - 48; ch = getchar(); }return x * f;
}int main() {int a = read(), b = read(), c = read(), d = read();int sqra = sqrt(2 * a), sqrd = sqrt(2 * d);bool ans = true;if ((a + b + c + d) == 0) {puts("0");return 0;}if (sqra * (sqra + 1) != a * 2 || sqrd * (sqrd + 1) != d * 2) {ans = false;} else {int cnt0 = sqra, cnt1 = sqrd;cnt0++, cnt1++;if (cnt1 == 1 && (b + c) == 0) cnt1 = 0;if (cnt0 == 1 && (b + c) == 0) cnt0 = 0;//printf("%d %d\n", cnt0, cnt1);if (b + c != cnt0 * cnt1) {ans = false;} else {if (cnt1 == 0) {while (cnt0--) putchar('0');return 0;}if (cnt0 == 0) {while (cnt1--) putchar('1');return 0;}int k = b / cnt1;for (int i = cnt0; i > cnt0 - k; i--) putchar('0');cnt0 -= k;k = b - k * cnt1;if (k) {k = cnt1 - k;for (int i = cnt1; i > cnt1 - k; i--) putchar('1');cnt1 -= k;putchar('0'), cnt0--;}    while (cnt1--) putchar('1');while (cnt0--) putchar('0');return 0;}}if (!ans) puts("impossible");return 0; 
}
View Code

 

K - King's Colors Gym - 101933K

题意:一棵树n个节点,k种颜色,问有多少种方案用上k个颜色并且相邻两节点颜色不同

我以为要用树形dp做,赛后看题解才明白是个容斥。

用k种的情况是$k\times \left( k-1\right) ^{n-1}$然后其中包含了只用了k-1种 只用了k-2种...的情况

容斥一下就好了

#include <bits/stdc++.h>
#define ll long long
using namespace std;inline ll read() {ll x = 0, f = 1; char ch = getchar();while (ch < '0' || ch > '9') { if (ch == '-') f = -1; ch = getchar(); }while (ch >= '0' && ch <= '9') { x = x * 10 + ch - '0'; ch = getchar(); }return x * f;
}const ll mod = 1e9 + 7;
const int N = 2550;
ll C[N][N];
void init() {for (int i = 0; i < N; i++) C[i][0] = 1, C[i][1] = i;for (int i = 1; i < N; i++)for (int j = 2; j <= i; j++)C[i][j] = (C[i-1][j-1] + C[i-1][j]) % mod;
}ll qm(ll a, ll b) {ll res = 1;while (b) {if (b & 1) res = res * a % mod;a = a * a % mod;b >>= 1;}return res;
}int main() {init();ll n = read(), k = read();for (int i = 1; i < n; i++) read();ll ans = 0, flag = 1;for (int i = k; i >= 1; i--) {ll temp = flag * i * qm((ll)i - 1, n - 1) % mod * C[k][i];ans = (ans + temp + mod) % mod;flag = -flag;}        printf("%lld\n", ans);return 0;
}
View Code

 

转载于:https://www.cnblogs.com/Mrzdtz220/p/10788014.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/448904.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

消息队列技术介绍 : ActiveMQ、RabbitMQ、ZeroMQ、Kafka、MetaMQ、RocketMQ

一、 消息队列概述 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 消息队列中间件是分布式系统中重要的组件&#xff0c;主要解决应用耦合、异步消息、流量削锋等问题。实现高性能、高可…

python爬虫学习之页面登陆

爬虫学习的一点心得 登陆主要有3种方法&#xff1a;使用selenium&#xff0c;cookies&#xff0c;模拟表单登陆 个人对于一般情况使用cookies登陆 可以实现一次手动&#xff0c;长期自动&#xff0c;可以绕过登陆&#xff08;登陆的相关信息密码&#xff0c;账号等会存于cookie…

消息队列 应用场景 解析

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 另外腾讯云-云社区还有一文不允许转载&#xff0c;但内容挺好的&#xff1a;https://cloud.tencent.com/developer/article/1006035 分布…

利用memcached实现CAS单点登录集群部署

前言&#xff1a;利用memcached实现CAS单点登录集群部署 负载均衡&#xff1a;将接口请求的有状态性变成无状态性。是我们在实现负载均衡时必要要解决的问题。以应用接口的session状态为例&#xff0c;一般解决方法都是将session数据和应用进行剥离&#xff0c;session数据统一…

分布式开放消息系统 ( RocketMQ ) 的原理与实践

分布式消息系统作为实现分布式系统可扩展、可伸缩性的关键组件&#xff0c;需要具有高吞吐量、高可用等特点。而谈到消息系统的设计&#xff0c;就回避不了两个问题&#xff1a; 消息的顺序问题消息的重复问题RocketMQ作为阿里开源的一款高性能、高吞吐量的消息中间件&#xff…

数据结构02-链表

说明&#xff1a;由于该数据结构是由java并且是原生实现&#xff0c;所以与C有一些出入&#xff0c;不过原理是相同的 1.链表的定义 为了表示线性表元素a与a1的逻辑关系&#xff0c;存储数据时&#xff0c;除了存储元素本身的信息之外&#xff0c;还存储了直接后继元素的位置信…

洛谷P2347 砝码称重 某一年noip提高组原题

可以转化为01背包求方案数的问题&#xff0c;dp数组f[][]表示第几个砝码能称出的重量,可压缩至一维 转移方程为f(i,j)f(i-1,j-w[i]) 当前我们可以称出的重量必定是由之前的砝码重量转移过来的 #include<bits/stdc.h> using namespace std; const int N550; const int max…

linux 下载、安装 maven

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 1. 创建maven的文件夹并下载maven的tar包到此文件夹中 //进入一个目录 cd /usr/local//创建一个文件夹 mkdir maven//下载maven的tar包…

c# 编程学习(二)

2019独角兽企业重金招聘Python工程师标准>>> 标识符是对程序中的各个元素进行标识的名称。  只能使用字母(大写和小写)、数字和下划线  标识符必须以字母或下划线开头 变量是容纳值的存储位置。可将变量想象成容纳临时信息的容器 命名变量的建议&#xff1a; …

深入理解C++ 虚函数表

目录 深入理解C 虚函数表虚函数表概述单继承下的虚函数表派生类未覆盖基类虚函数派生类覆盖基类虚函数多继承下的虚函数表无虚函数覆盖派生类覆盖基类虚函数钻石型虚继承总结几个原则安全性问题深入理解C 虚函数表 ​ C中的虚函数的作用主要是实现了多态的机制。关于多态&#…

Bootstrap简介

1.使用准备 1.1 Bootstrap的下载 http://www.bootcss.com&#xff0c;下载用于生产环境的Bootstrap即可。 1.2 Bootstrap包含的内容 ● 全局CSS&#xff1a;基本的 HTML 元素均可以通过 class 设置样式并得到增强效果&#xff1b;还有先进的栅格系统。 ● 组件&#xff1a;无数…

tomcat需要设置环境变量吗

tomcat是一款轻量级web应用服务器&#xff0c;安装的时候我们都是直接解压zip包&#xff0c;然后在bin目录下双击startup.bat就可以启动了&#xff08;当然&#xff0c;前提是本地要安装jdk并配置JAVA_HOME环境变量&#xff09; 所以我一直认为tomcat是不用配置环境变量的 但是…

钱荒下银行理财收益率角逐:邮储银行垫底

21世纪资管研究员松壑 由于银行理财的收益定价机制为设定预期收益率的“先行定价”&#xff0c;而银行对产品本金收益又保有或明或暗的兑付要求&#xff0c;其业绩往往在理财产品发行前就已决定。 因此&#xff0c;本次榜单根据已披露最高预期收益率&#xff08;下称收益率&a…

数据结构7.3_图的遍历

我们希望从图中某一顶点出发访遍图中其余顶点&#xff0c;且使每一个顶点仅被访问一次。 这一过程就叫做图的遍历。 图的遍历算法是求解图的连通性问题、拓扑排序和求关键路径等算法的基础。 然而&#xff0c;图的遍历要比树的遍历复杂得多。 因为图的任一顶点都可能和其余的顶…

HCL实验四

PC端配置&#xff1a;配置ip地址 配置网关 交换机配置&#xff1a;①创建VLAN system-view vlan 10 vlan 20 ②配置PC端接口 interface vlan-interface 10 ip add 192.168.10.254 24 interface vlan-interface 20 ip add 192.168.20.254 24 转载于:https://www.cnblogs.com/zy5…

程序员/设计师能用上的 75 份速查表

本文由 伯乐在线 - 黄利民 翻译自 designzum。欢迎加入 技术翻译小组。转载请参见文章末尾处的要求。75 份速查表&#xff0c;由 vikas 收集整理&#xff0c;包括&#xff1a;jQuery、HTML、HTML5、CSS、CSS3、JavaScript、Photoshop 、git、Linux、Java、Perl、PHP、Python、…

GWAS: 网页版的基因型填充(genotype imputation)

在全基因组关联分析中&#xff0c;处理芯片数据时&#xff0c;必须走的一个流程就是基因型数据填充&#xff08;imputation&#xff09;。 当然&#xff0c;如果你拿到的是全测序的数据&#xff0c;请忽略这一步。 下面直奔主题&#xff0c;怎么在网页版进行基因型填充。 1 进入…

腾讯CKV海量分布式存储系统

摘要&#xff1a;腾讯CKV&#xff0c;是腾讯自主研发的高性能、低延时、持久化、分布式KV存储服务。在腾讯的微信平台、开放平台、腾讯云、腾讯游戏和电商平台广泛使用&#xff0c;日访问量超过万亿次。本文将全面剖析CKV的实现原理和技术挑战。 与Memcached和Redis等开源NoSQ…

编程之法:面试和算法心得

《编程之法&#xff1a;面试和算法心得》高清中文版PDF 含书目录 下载地址&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1Kcd2bRsIfhagKZR6NaOgXg 提取码&#xff1a;054s 《编程之法&#xff1a;面试和算法心得》高清中文版PDF高清中文版PDF 含书目录&#xff0c;36…

localStorage存、取数组

localStorage存储数组时需要先使用JSON.stringify()转成字符串&#xff0c;取的时候再字符串转数组JSON.parse()。 var arr[1,2,3,4];localStorage.setItem(key,arr);console.log(localStorage(key); //打印出字符串&#xff1a;1,2,3,4 正常存储&#xff1a;localStorage.setI…