Atcoder ABC138
Atcoder ABC138
A .Red or Not
一道网速题。
大于3200输出原字符串,否则就输出red。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define LL long long
int a;
string ch;
int main() {
scanf("%d",&a);
cin>>ch;
if(a >= 3200) cout<<ch;
else puts("red");
//system("pause");
return 0;
}
B. Resistors in Parallel
这不是网速题了,是一道手速题。(滑稽.jpg)
直接暴力求所有数的倒数和,再对所有数的倒数和取倒数就行了,不用考虑精度问题。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 120
using namespace std;
int a[N],n;
double s;
int main() {
cin >> n;
for(int i = 1 ; i <= n ; i++) {
double x ;
cin>>x ;
x = 1 / x ;
s += x ;
}
cout<<1 / s<<endl;
system("pause");
return 0;
}
C. Alchemist
比之前的两道题要略难一点。
考虑对数组从小到大进行一次排序,然后每次贪心的取两个最小的值。
答案就是最后修改的值。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define LL long long
#define N 1010
int a[N],n;
double b[N];
int main() {
scanf("%d",&n);
for(int i = 1 ; i <= n ; i++)
scanf("%d",&a[i]);
sort(a + 1,a + n + 1);
int p1 = 2,p2 = 3;
b[p1] = ((double)a[1] + (double)a[2]) / 2;
while(p2 <= n) {
//printf("%d %d\n",&a[p1],&a[p2]);
b[p2] = ((double)b[p1] + (double)a[p2]) / 2;
// printf("%lf \n",b[p2]);
p1++,p2++;
//printf("%d %d \n",p1,p2);
}
//for(int i = 1 ; i <= n ; i++) printf("%d ",a[i]);
printf("%lf \n",b[n]);
//system("pause");
return 0;
}
D.Strings of Impurity
数据只有2e6,所以就是一道树链剖分ZZ题。
只需要写子树修改和链查询就可以。
题目中要求的单点查询可以看作查询自己到自己这条链的权值。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define LL long long
#define N 1000010
struct Edge {
int to,from;
}e[N*2+10];
struct Tree {
int sum,tag;
int lson,rson;
}tree[N*2];
int deep[N],Top[N],idx[N],siz[N];
int n,m,p,root,son[N],tot = 1,cnt;
int head[N],fa[N],val[N],w[N],t;
inline void add_edge(int x,int y) {
e[++cnt].from = y;
e[cnt].to = head[x];
head[x] = cnt;
}
inline void pushup(int x) {
tree[x].sum = (tree[tree[x].lson].sum + tree[tree[x].rson].sum);
}
void pushdown(int x,int l,int r) {
int mid = (l + r) >> 1;
tree[tree[x].lson].sum = (tree[tree[x].lson].sum + tree[x].tag * (mid - l + 1));
tree[tree[x].rson].sum = (tree[tree[x].rson].sum + tree[x].tag * (r - mid));
tree[tree[x].lson].tag = (tree[tree[x].lson].tag + tree[x].tag);
tree[tree[x].rson].tag = (tree[tree[x].rson].tag + tree[x].tag);
tree[x].tag = 0;
}
void build(int x,int l,int r) {
if(l == r) {
tree[x].sum = w[l];
return;
}
int mid = (l + r) >> 1;
tree[x].lson = ++tot;
build(tree[x].lson,l,mid);
tree[x].rson = ++tot;
build(tree[x].rson,mid+1,r);
pushup(x);
}
void update(int x,int l,int r,int ll,int rr,int v) {
if(l == ll && r == rr) {
tree[x].sum = (tree[x].sum + (r - l + 1) * v);
tree[x].tag = (tree[x].tag + v);
return;
}
int mid = (l + r) >> 1;
pushdown(x,l,r);
if(rr <= mid) update(tree[x].lson,l,mid,ll,rr,v);
else if(ll > mid) update(tree[x].rson,mid+1,r,ll,rr,v);
else {
update(tree[x].lson,l,mid,ll,mid,v);
update(tree[x].rson,mid+1,r,mid+1,rr,v);
}
pushup(x);
}
inline int query(int x,int l,int r,int ll,int rr) {
if(l == ll && r == rr) return tree[x].sum;
int mid = (l + r) >> 1;
pushdown(x,l,r);
if(rr <= mid) return query(tree[x].lson,l,mid,ll,rr);
else if(ll > mid) return query(tree[x].rson,mid + 1,r,ll,rr);
else return (query(tree[x].lson,l,mid,ll,mid) + query(tree[x].rson,mid + 1,r,mid + 1,rr));
}
void dfs1(int x,int f,int depth) {
fa[x] = f;
siz[x] = 1;
deep[x] = depth;
int maxs = -1;
for(int i = head[x] ; i ; i = e[i].to) {
int u = e[i].from;
if(u == f) continue;
dfs1(u,x,depth + 1);
siz[x] += siz[u];
if(siz[u] > maxs) {
son[x] = u;
maxs = siz[u];
}
}
}
void dfs2(int x,int topf) {
idx[x] = ++t;
w[t] = val[x];
Top[x] = topf;
if(!son[x]) return;
dfs2(son[x],topf);
for(int i = head[x] ; i ; i = e[i].to) {
int u = e[i].from;
if(u == son[x] || u == fa[x]) continue;
dfs2(u,u);
}
}
inline int query_link(int x,int y) {
int ans = 0;
while(Top[x] != Top[y]) {
if(deep[Top[x]] < deep[Top[y]]) swap(x,y);
ans += query(1,1,n,idx[Top[x]],idx[x]);
ans %= p;
x = fa[Top[x]];
}
if(deep[x] > deep[y]) swap(x,y);
ans = (ans + query(1,1,n,idx[x],idx[y]));
return ans;
}
inline void update_link(int x,int y,int val) {
while(Top[x] != Top[y]) {
if(deep[Top[x]] < deep[Top[y]]) swap(x,y);
update(1,1,n,idx[Top[x]],idx[x],val);
x = fa[Top[x]];
}
if(deep[x] > deep[y]) swap(x,y);
update(1,1,n,idx[x],idx[y],val);
}
inline int query_tree(int x) {
return query(1,1,n,idx[x],idx[x] + siz[x] - 1);
}
inline void update_tree(int x,int val) {
update(1,1,n,idx[x],idx[x] + siz[x] - 1,val);
}
int main() {
scanf("%d%d",&n,&m);
for(int i = 1 ; i < n ; i++) {
int a,b;
scanf("%d%d",&a,&b);
add_edge(a,b);
add_edge(b,a);
}
dfs1(1,0,1);
dfs2(1,1);
build(1,1,n);
while(m--) {
int x,z;
scanf("%d%d",&x,&z);
update_tree(x,z);
}
for(int i = 1 ; i <= n ; i++)
printf("%d ",query_link(i,i));
//system("pause");
return 0;
}
E.Strings of Impurity
一道字符串题。
我们考虑在s串中查询t串中的每个字符出现的位置,统计出现了多少次,即统计需要循环s串多少次。
那么答案就是 $ cnt * s.length() + pos $ 。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
using namespace std;
#define LL long long
string s,t;
LL pos,cnt;
int main() {
cin>>s>>t;
for(int i = 0 ; i < t.length() ; i++) {
pos = s.find(t[i],pos);
if(pos == -1) {
pos = s.find(t[i],0);
if(pos == -1) {
puts("-1");
return 0;
}
cnt++;
}
pos++;
}
LL ans = cnt * s.length() + pos;
printf("%lld \n",ans);
//system("pause");
return 0;
}
F.Coincidence
一道极端恶心的DP题。
设 $ dp[i][0/1][0/1] $ 表示考虑到当前位置i,满足 $ x \geq L $ , 并且满足 $ y \leq R $ 的方案数。
因为数据上界为 $ 10^{18} $ ,不能直接存,所以我们考虑利用2进制,数组的第一维代表到 $ 2^i $ 的位置。
此时数组只需要开 $ dp[65][2][2] $ ,第一维只有65是因为 $ 2^{60} \geq 10^{18}$ 。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define LL long long
const int mod = 1e9 + 7;
LL dp[66][2][2],L, R;
LL dfs(int x, bool Left, bool Right, bool zero) {
if(x < 0) return 1;
if(dp[x][Left][Right] >= 0 && !zero)
return dp[x][Left][Right];
LL ans = 0;
int l = 0, r = 1;
if(Left) l = L >> x & 1;
if(Right) r = R >> x & 1;
for(int i = l ; i <= 1 ; i++) {
for (int j = i ; j <= r ; j++) {
if (j == 1 && zero) {
if(i == 1) ans += dfs(x-1, Left && i == l, Right && j == r, zero && j == 0);
}
else ans += dfs(x-1, Left && i == l, Right && j == r, zero && j == 0);
}
}
ans %= mod;
if(!zero) dp[x][Left][Right] = ans;
return ans;
}
int main() {
scanf("%lld%lld", & L, & R);
memset(dp, -1, sizeof(dp));
printf("%lld \n", dfs(60, 1, 1, 1));
//system("pause");
return 0;
}
Atcoder ABC138的更多相关文章
- AtCoder Regular Contest 061
AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...
- AtCoder Grand Contest 001 C Shorten Diameter 树的直径知识
链接:http://agc001.contest.atcoder.jp/tasks/agc001_c 题解(官方): We use the following well-known fact abou ...
- AtCoder Regular Contest 082
我都出了F了……结果并没有出E……atcoder让我差4分上橙是啥意思啊…… C - Together 题意:把每个数加1或减1或不变求最大众数. #include<cstdio> #in ...
- AtCoder Regular Contest 069 D
D - Menagerie Time limit : 2sec / Memory limit : 256MB Score : 500 points Problem Statement Snuke, w ...
- AtCoder Regular Contest 076
在湖蓝跟衡水大佬们打的第二场atcoder,不知不觉一星期都过去了. 任意门 C - Reconciled? 题意:n只猫,m只狗排队,猫与猫之间,狗与狗之间是不同的,同种动物不能相邻排,问有多少种方 ...
- AtCoder Grand Contest 016
在雅礼和衡水的dalao们打了一场atcoder 然而窝好菜啊…… A - Shrinking 题意:定义一次操作为将长度为n的字符串变成长度n-1的字符串,且变化后第i个字母为变化前第i 或 i+1 ...
- AtCoder Beginner Contest 069【A,水,B,水,C,数学,D,暴力】
A - K-City Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement In K-city, ...
- AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle
https://beta.atcoder.jp/contests/abc075/tasks/abc075_d 题意: 给出坐标平面上n个点的坐标,要求找到一个面积最小的矩形使得这个矩形的边界加上内部的 ...
- AtCoder Beginner Contest 073
D - joisino's travel Time Limit: 2 sec / Memory Limit: 256 MB Score : 400400 points Problem Statemen ...
随机推荐
- C# 中使用正则表达式 Regex.Matches方法的几个应用[转]
用于正则表达式的 Regex.Matches静态方法的几种用法: //①正则表达式 = > 匹配字符串 string Text = @"This is a book , this is ...
- arcgis之gp服务发布
arcgis之gp服务发布 注意: 1.arcgis服务可以直接通过arcmap来发布,gp服务就是将arcmap中的工具发布为服务,达到线上处理数据的能力 2.以文件为参数时不要以文件直接为参数,可 ...
- Vue中断axios请求-切换页面+重复请求
切换页面时中断 一.概述 在Vue单页面开发过程中,遇到这样的情况,当我切换页面时,由于上一页面请求执行时间长,切换到该页面时,还未执行完,这时那个请求仍会继续执行直到请求结束,此时将会影响页面性能, ...
- 18.SSM整合_搭建开发环境
1.导入jar包 mybatis的Jar包 ehcache的Jar包 spring的 Jar包 mybatis 与 spring 整合Jar包 JSON的jar包 Jaskson的Jar包 Hiber ...
- MySQL cmd操作
1.开启关闭服务 net start mysql net stio mysql 2.登陆 在CMD命令窗口敲入命令 mysql -hlocalhost -uroot -p 后按回车(注意这里的&quo ...
- 生成漂亮报告的Go语言代码检查工具
上篇文章,老司机给各位同学介绍了Go语言的静态代码测试“三板斧”以及Go语言的testing类库. “三板斧”简洁明了,但是缺点也很明显,命令行执行,命令行输出.适合研发攻城狮看,不适合交给领导过目. ...
- Files的常用方法都有哪些?(未完成)
Files的常用方法都有哪些?(未完成)
- 学习kafka笔记
一:概念 Kafka是一个分布式的消息队列,相当于我们生活中的快递柜,快递点,快递员将快递放到快递柜中,收件人去取,把快递(消息)的入柜(入队)和处理进行解耦,使得双方以自己合适的时间和频率处理快递, ...
- HashMap源码分析四
HashMap源码在jdk1.8中,改动挺大,里面内容已经变的非常复杂了,后面另起博客分析.jdk1.8以前,HashMap一直是数组加链表的数据结构,在数组的某个下标位置,有多次碰撞,则使用 ...
- CSS3 -- 边框圆角
文章后有彩蛋哦 <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...