Preliminaries for Benelux Algorithm Programming Contest 2019
A. Architecture
如果行最大值中的最大值和列最大值中的最大值不同的话,那么一定会产生矛盾,可以手模一个样例看看。
当满足行列最大值相同条件的时候,就可以判定了。
因为其余的地方一定可以构造出来符合条件的值,行列是很多的,填0就好了。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
int n, m; cin >> n >> m;
int t1, t2;
t1 = t2 = 0;
for(int i = 1, x; i <= n; i++)
{
scanf("%d", &x);
t1 = max(t1, x);
}
for(int i = 1, x; i <= m; i++)
{
scanf("%d", &x);
t2 = max(t2, x);
}
if(t1 == t2) puts("possible");
else puts("impossible");
return 0;
}
B. Bracket Sequence
用栈模拟即可,注意要取模
const int N = 300000 + 5;
const int mod = 1e9 + 7;
ll st[N], top, cnt;
int n;
char op[20];
ll get(char *s){
int len = strlen(s);
ll x = 0;
for(int i=0;i<len;i++) x = x * 10 + s[i] - '0';
return x;
}
int main() {
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%s",op);
if(op[0] == '(') {
cnt ++;
st[++top] = -1;
continue;
}
else if(op[0] == ')'){
if(st[top] == -1) {
top --;
continue;
}
ll x = st[top];
while(top >= 2 && st[top-1] != -1){
if(cnt % 2 == 0)x = (st[top-1] + x)%mod;
else x = st[top-1] * x % mod;
top--;
}
cnt --;
top -= 2;
st[++top] = x;
}
else{
ll x = get(op);
st[++top] = x;
}
}
ll res = 0;
while(top) res = (res + st[top--]) % mod;
printf("%lld\n", res);
return 0;
}
C. Canyon Crossing
二分一下最低高度,然后整个图变成了 n*m 个点,边权为0或1的图,第一排为起点,最后一排为终点,跑最短路即可,由于边权只有0和1,所以用双端队列维护即可
const int N = 1000 + 5;
#define mk make_pair
int n, m, k, a[N][N];
int d[N][N],c[N][N];
int dx[4] = {1,-1,0,0}, dy[4] = {0,0,1,-1};
pair<int,int> q[2000010];
bool check(int mid){
memset(d, 0x3f, sizeof d);
int l = 1000005,r = 1000004;
for(int j=1;j<=m;j++)q[++r] = mk(0,j), d[0][j] = 0;
while(l<=r){
auto t = q[l++];
int x = t.first, y = t.second;
for(int i=0;i<4;i++){
int nx = x + dx[i], ny = y + dy[i];
if(nx < 1 || nx > n || ny < 1 || ny > m)continue;
if(a[nx][ny] >= mid){
if(d[nx][ny] > d[x][y]){
d[nx][ny] = d[x][y];
q[--l] = mk(nx,ny);
}
}else{
if(d[nx][ny] > d[x][y] + 1){
d[nx][ny] = d[x][y] + 1;
q[++r] = mk(nx,ny);
}
}
}
}
for(int i=1;i<=m;i++)if(d[n][i] <= k) return true;
return false;
}
int main() {
scanf("%d%d%d",&n,&m,&k);
int l = inf, r = 0;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
scanf("%d",&a[i][j]);
l = min(l, a[i][j]);
r = max(r, a[i][j]);
}
}
while(l < r){
int mid = l + r + 1 >> 1;
if(check(mid))l = mid;
else r = mid - 1;
}
printf("%d\n",l);
return 0;
}
D. Deceptive Dice
\(ans\) 为 \(i-1\) 轮的期望,设 \(t = \lfloor ans \rfloor\) ,那么第 \(i\) 轮的期望是
\]
前面的表示有 \(t/n\) 的概率小于等于ans,那么第 i 次就不再掷色子。后面的就是取 [i+1, n]
的期望
const int N = 100 + 5;
int n, m;
double ans;
int get(int x){return x*(x+1) / 2;}
int main() {
scanf("%d%d",&n,&m);
ans = 1.0 * get(n) / n;
for(int i=2;i<=m;i++){
int t = ans;
ans = 1.0 * t / n * ans + 1.0 * (get(n) - get(t)) / n;
}
printf("%.7f\n",ans);
return 0;
}
E. Exits in Excess
这个题有个关键的性质在于无自环。
设两个集合\(S,T\)。
考虑一条边\(<x,y>\),如果\(x<y\),将这条边插入\(S\);否则插入\(T\)。
输出边集大小较小的集合。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
vector<int> t1, t2;
int n, m;
int main()
{
cin >> n >> m;
for(int i = 1, x, y; i <= m; i++)
{
scanf("%d%d", &x, &y);
if(x < y) t1.push_back(i);
else t2.push_back(i);
}
if(t1.size()>t2.size()) t1 = t2;
cout << t1.size() << endl;
for(auto x : t1)
printf("%d\n", x);
return 0;
}
F. Floor Plan
int n;
int main() {
cin >> n;
int flag = false;
for(int i=2;i*i<=n;i++){
if(n % i == 0){
int res = n / i;
if((res + i)%2 == 0){
flag = true;
int a = (res + i) / 2;
int b = res - a;
printf("%d %d\n",b, a);
break;
}
}
}
if(!flag) puts("impossible");
return 0;
}
G. Greetings!
const int N = 100000 + 5;
char s[N];
int main() {
cin >> s;
int n = strlen(s);
printf("h");
for(int i=0;i<2*(n-2);i++)printf("e");
printf("y");
return 0;
}
H. Hexagonal Rooks
从起点走两步走到终点,枚举中间的那个点,判断它与起点和终点是否可以一步达到即可,判断细节比较重要,把大于纵坐标大于 'f' 的对称往上翻即可,用几种case找找规律即可。
char x, x2;
int y, y2;
bool check(int x, int y, int x2, int y2){
if(x == x2 && y == y2) return false;
if(x == x2) return true;
if(x > 6) y += x - 6;
if(x2 > 6) y2 += x2 - 6;
if(y == y2 || y - x == y2 - x2) return true;
return false;
}
int main() {
cin >> x >> y >> x2 >> y2;
int res = 0;
for(int i=1;i<=11;i++){
int cnt = 11 - abs(6 - i);
for(int j=1;j<=cnt;j++){
if(check(i, j, x-'a'+1, y) && check(i, j, x2-'a'+1, y2)) res++;
}
}
cout << res << endl;
return 0;
}
I. Inquiry I
const int N = 1000000 + 5;
ll a[N], b[N], sa[N], sb[N];
int n;
int main() {
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%lld",&a[i]),b[i] = a[i]*a[i];
ll res = 0;
for(int i=1;i<=n;i++) sa[i] = sa[i-1] + a[i], sb[i] = sb[i-1] + b[i];
for(int i=0;i<=n;i++){
res = max(res, sb[i] * (sa[n] - sa[i]));
}
printf("%lld\n",res);
return 0;
}
K. Knapsack Packing
首先排个序,最小的一定是0(空集产生的和),然后次小的就是集合中最小的数了。之后每次找到一个新的数字(即最终答案集合中的数字),都用它与之前所有组合出来的数字进行求和,将这些新的数字填入到一个集合中,再接下来的扫描过程中,如果发现有该集合的数字,则一定不是答案集合中的数字,将其从集合中删除即可。
const int N = 300000 + 5;
int n, m, a[N];
multiset<int> st, tmp;
map<int,int> mp;
vector<int> res;
int main() {
scanf("%d",&n);
m = 1 << n;
for(int i=1;i<=m;i++)scanf("%d",&a[i]);
sort(a+1,a+1+m);
if(a[1] != 0){
puts("impossible");
return 0;
}
int cnt = 0;
for(int i=2;i<=m;i++){
if(mp[a[i]]){
mp[a[i]] --;
continue;
}else{
cnt ++;
res.push_back(a[i]);
for(auto x:st){
tmp.insert(x + a[i]);
}
for(auto x : tmp) {
st.insert(x);
mp[x] ++;
}
st.insert(a[i]);
tmp.clear();
}
if(cnt > n){
puts("impossible");
return 0;
}
}
sort(res.begin(),res.end());
for(auto x : res)printf("%d\n",x);
return 0;
}
L. Lifeguards
将点按照坐标轴排序,找到中间的点,对于n的奇偶进行分别处理。
n 为奇数则构造一个几乎平行于y轴且通过中间点的直线,可以想到做这条直线的垂直平分线可以将所有点分成两半
n 为偶数则构造一个几乎平行于y轴且不通过中间点的直线,这样的直线的垂直平分线也同样会把所有点分成两半
const int N = 100000 + 5;
pair<ll,ll> a[N];
int n;
int main() {
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%lld%lld",&a[i].first, &a[i].second);
sort(a + 1, a + 1 + n);
int mid = (n + 1) / 2;
ll Len = 1000000000000ll;
ll x = a[mid].first, y = a[mid].second;
if(n & 1){
printf("%lld %lld\n", x - Len, y-1);
printf("%lld %lld\n", x + Len, y+1);
}else{
printf("%lld %lld\n", x - Len, y);
printf("%lld %lld\n", x + Len, y+1);
}
return 0;
}
Preliminaries for Benelux Algorithm Programming Contest 2019的更多相关文章
- 2020.3.14--训练联盟周赛 Preliminaries for Benelux Algorithm Programming Contest 2019
1.A题 题意:给定第一行的值表示m列的最大值,第m行的值表示n行的最大值,问是否会行列冲突 思路:挺简单的,不过我在一开始理解题意上用了些时间,按我的理解是输入两组数组,找出每组最大数,若相等则输出 ...
- ICPC训练联盟周赛Preliminaries for Benelux Algorithm Programming Contest 2019
I题 求 a 数组平方的前缀和和求 a 数组后缀和,遍历一遍即可 AC代码 #include<iostream>#include<cmath>using namespace s ...
- 03.14 ICPC训练联盟周赛,Preliminaries for Benelux Algorithm Programming Contest 2019
A .Architecture 题意:其实就是想让你找到两行数的最大值,然后比较是否相同,如果相同输出'possible',不同则输出'impossible' 思路:直接遍历寻找最大值,然后比较即可 ...
- ICPC训练周赛 Benelux Algorithm Programming Contest 2019
D. Wildest Dreams 这道题的意思是Ayna和Arup两人会同时在车上一段时间,在Ayna在的时候,必须单曲循环Ayna喜欢的歌,偶数段Ayna下车,若此时已经放了她喜欢的那首歌,就要将 ...
- Benelux Algorithm Programming Contest 2019
J. Jazz it Up!题目要求,n*m的因子中不能含有平方形式,且题目中已经说明n是一个无平方因子的数, 那么只要m是无平方因子的数,并且n和m没有共同的因子即可.要注意时间复杂度!代码:#in ...
- 2020.3.21--ICPC训练联盟周赛Benelux Algorithm Programming Contest 2019
A Appeal to the Audience 要想使得总和最大,就要使最大值被计算的次数最多.要想某个数被计算的多,就要使得它经过尽量多的节点.于是我们的目标就是找到 k 条从长到短的链,这些链互 ...
- Benelux Algorithm Programming Contest 2014 Final(第二场)
B:Button Bashing You recently acquired a new microwave, and noticed that it provides a large number ...
- 2014 Benelux Algorithm Programming Contest (BAPC 14)E
题目链接:https://vjudge.net/contest/187496#problem/E E Excellent Engineers You are working for an agency ...
- 计蒜客 28319.Interesting Integers-类似斐波那契数列-递推思维题 (Benelux Algorithm Programming Contest 2014 Final ACM-ICPC Asia Training League 暑假第一阶段第二场 I)
I. Interesting Integers 传送门 应该是叫思维题吧,反正敲一下脑壳才知道自己哪里写错了.要敢于暴力. 这个题的题意就是给你一个数,让你逆推出递推的最开始的两个数(假设一开始的两个 ...
随机推荐
- Centos7 Nginx+PHP7 配置
Centos7 Nginx+PHP7 配置 内容: 源码编译安装Nginx和PHP 配置PHP和Nginx,实现Nginx转发到PHP处理 测试 设置Nginx.PHP开机自启 安装的版本: Ngin ...
- 使用Jenkins+Blue Ocean 持构建自动化部署之安卓源码打包、测试、邮件通知
什么是BlueOcean? BlueOcean重新考虑了Jenkins的用户体验.BlueOcean由Jenkins Pipeline设计,但仍然兼容自由式工作,减少了团队成员的混乱,增加了清晰度. ...
- CVE-2019-15107_webmin漏洞复现
一.漏洞描述 Webmin的是一个用于管理类Unix的系统的管理配置工具,具有网络页面.在其找回密码页面中,存在一处无需权限的命令注入漏洞,通过这个漏洞攻击者即可以执行任意系统命令.它已知在端口100 ...
- 【Linux】salt的cmd.script命令介绍
salt是一个很棒的自动化运维工具之一,常用的有cmd.run,今天介绍的是cmd.script 其实一眼就能看出这个命令是执行脚本的命令 具体操作如下: 1.将/etc/salt/master中的 ...
- leetcode 93. Restore IP Addresses(DFS, 模拟)
题目链接 leetcode 93. Restore IP Addresses 题意 给定一段序列,判断可能组成ip数的所有可能集合 思路 可以采用模拟或者DFS的想法,把总的ip数分成四段,每段判断是 ...
- Jenkins自动部署spring boot
Jenkins自动部署spring boot 背景介绍 本公司属于微小型企业,初期业务量不高,所有程序都写在一个maven项目里面,不过是多模块开发. 分了login模块,service模块,cms模 ...
- LuoguP5748 集合划分计数
题意 一个有\(n\)个元素的集合,将其分为任意个非空子集,求方案数.集合之间是无序的,\(\{\{1,2\},\{3\}\}=\{\{3\},\{1,2\}\}\). 设\(f_n\)表示用\(n\ ...
- ichartjs插件的使用
项目中可能会用到饼状图.柱状图.环形图等,ichartjs是一个很不错的插件,体量小,只需引入ichart.1.2.1.min.js即可满足基础需求,github下载地址是:https://githu ...
- 图像Demosaic算法及其matlab实现
由于成本和面积等因素的限定,CMOS/CCD在成像时,感光面阵列前通常会有CFA(color filter array),如下图所示,CFA过滤不同频段的光,因此,Sensor的输出的RAW数据信号包 ...
- Azure Terraform(七)利用Azure DevOps 实现自动化部署基础资源(补充)
一,引言 之前一篇文章有讲解到利用 利用Azure DevOps 实现自动化部署基础资源,当时 TF 代码没有针对 Azure 各个资源的封装,所有的资源代码全部写在一个 main.tf 文件中.然后 ...