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 ...
随机推荐
- 微信公众号支付备忘及填坑之路-java
一.背景 最近公司给第三方开发了一个公众号,其中最重要的功能是支付,由于是第一次开发,遇到的坑特别的多,截止我写博客时,支付已经完成,在这里我把遇到的坑记录一下(不涉及退款).不得不吐槽一下,腾讯这么 ...
- sqlserver跨库操作数据
垮库只能读操作,写操作需要设置权限. USE [jdddb] GO /****** Object: StoredProcedure [dbo].[proc_LYOrderCancel] Script ...
- [转载]IMDB文件格式
[转载]IMDB文件格式 来源:LMDB的全称是Lightning Memory-Mapped Database,闪电般的内存映射数据库.它文件结构简单,一个文件夹,里面一个数据文件,一个锁文件.数据 ...
- .NET 反射应用
object request = null; string requestObjClassName = "命名空间" + 类型.ToString(); Type type = Ty ...
- c#如何使用MemoryStream和BinaryFormatter进行对象的序列化和返序列化
1 下面是我写的一个序列化的类 public static class ObjSerialize { /// <summary> /// 将对象数组obj序列化,内存中的缓冲区的数据序列化 ...
- 文件 file open函数的打开及 函数的调用
文件 mode 模式字符的含义 字符 含义 'r' 以只读方式打开(默认) 'w' 以只写方式打开,删除原有文件内容(如果文件不存在,则创建该文件并以只写方式打开) 'x' 创建一个新文件, 并以写模 ...
- maskrcnn-benchmark错误:ImportError: cannot import name rnn_compat
错误: from apex import amp File "build/bdist.linux-x86_64/egg/apex/__init__.py", line 5, in ...
- 10_Hive自定义函数UDF
Hive官方的UDF手册地址是:https://cwiki.apache.org/confluence/display/Hive/LanguageManual+UDF 1.使用内置函数的快捷方法: 创 ...
- HandlerMethodArgumentResolver完美解决 springmvc注入参数多传报错
作为一个后端开发,能友好兼容前端参数传入错误等问题,在前端发布不小心多传一个参数导致系统错误的问题,一个广告系统是零容忍的,所以为了不犯错误,后端接收参数必须摒弃spring 的自动注入@Reques ...
- 5.caffe图片分类流程
一次创建下列文件: 1,create_txt.sh (create_filelist.sh) 2,create_lmdb.sh 3,make_mean.sh 4,train.prototxt+val. ...