AGC015

A - A+...+B Problem

#include <bits/stdc++.h>
#define fi first
#define se second
#define pii pair<int,int>
#define mp make_pair
#define pb push_back
#define space putchar(' ')
#define enter putchar('\n')
#define eps 1e-10
#define MAXN 300005
//#define ivorysi
using namespace std;
typedef long long int64;
typedef unsigned int u32;
typedef double db;
template<class T>
void read(T &res) {
res = 0;T f = 1;char c = getchar();
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 +c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
int64 N,A,B;
void Solve() {
read(N);read(A);read(B);
if(A > B) {puts("0");return;}
if(A == B) {puts("1");return;}
if(N == 1) {puts("0");return;}
out(A + B * (N - 1) - B - A * (N - 1) + 1);enter;
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
}

B - Evilator

如果是U的话下面的层需要坐两次,D的话上面的层需要坐两次

#include <bits/stdc++.h>
#define fi first
#define se second
#define pii pair<int,int>
#define mp make_pair
#define pb push_back
#define space putchar(' ')
#define enter putchar('\n')
#define eps 1e-10
#define MAXN 100005
//#define ivorysi
using namespace std;
typedef long long int64;
typedef unsigned int u32;
typedef double db;
template<class T>
void read(T &res) {
res = 0;T f = 1;char c = getchar();
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 +c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
char s[MAXN];
int64 ans;
int N;
void Solve() {
scanf("%s",s + 1);
N = strlen(s + 1);
for(int i = 1 ; i <= N ; ++i) {
if(s[i] == 'U') ans += N - i + (i - 1) * 2;
else ans += i - 1 + (N - i) * 2;
}
out(ans);enter;
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
}

C - Nuske vs Phantom Thnook

因为形成一个森林,我们只需要查询这个边框里面有多少个树根以及断开了多少父亲与儿子之间的边

#include <bits/stdc++.h>
#define fi first
#define se second
#define pii pair<int,int>
#define mp make_pair
#define pb push_back
#define space putchar(' ')
#define enter putchar('\n')
#define eps 1e-10
#define MAXN 100005
//#define ivorysi
using namespace std;
typedef long long int64;
typedef unsigned int u32;
typedef double db;
template<class T>
void read(T &res) {
res = 0;T f = 1;char c = getchar();
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 +c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
int N,M,Q;
char s[2005][2005];
int ch[4][2005][2005],sum[2005][2005],fa[2005 * 2005];
int dx[4] = {0,1,0,-1},dy[4] = {1,0,-1,0};
int id(int x,int y) {
return (x - 1) * M + y;
}
int getfa(int u) {
return fa[u] == u ? u : fa[u] = getfa(fa[u]);
}
void dfs(int x,int y) {
for(int k = 0 ; k < 4 ; ++k) {
int tx = x + dx[k],ty = y + dy[k];
if(s[tx][ty] == '1') {
if(fa[id(x,y)] != id(tx,ty)) {
ch[k][tx][ty] = 1;
fa[id(tx,ty)] = id(x,y);
dfs(tx,ty);
}
}
}
}
void Solve() {
read(N);read(M);read(Q);
for(int i = 1 ; i <= N ; ++i) {
scanf("%s",s[i] + 1);
}
for(int i = 1 ; i <= N ; ++i) {
for(int j = 1 ; j <= M ; ++j) {
if(s[i][j] == '1' && !fa[id(i,j)]) {
sum[i][j] = 1;
dfs(i,j);
}
}
}
for(int i = 1 ; i <= N ; ++i) {
for(int j = 1 ; j <= M ; ++j) {
sum[i][j] += sum[i][j - 1];
}
}
for(int i = 1 ; i <= N ; ++i) {
for(int j = 1 ; j <= M ; ++j) {
sum[i][j] += sum[i - 1][j];
}
}
for(int j = 1 ; j <= M ; ++j) {
for(int i = 1 ; i <= N ; ++i) {
ch[0][i][j] += ch[0][i - 1][j];
ch[2][i][j] += ch[2][i - 1][j];
}
}
for(int i = 1 ; i <= N ; ++i) {
for(int j = 1 ; j <= M ; ++j) {
ch[1][i][j] += ch[1][i][j - 1];
ch[3][i][j] += ch[3][i][j - 1];
}
}
int x[2],y[2];
for(int i = 1 ; i <= Q ; ++i) {
read(x[0]);read(y[0]);read(x[1]);read(y[1]);
int ans = 0;
ans += ch[0][x[1]][y[0]] - ch[0][x[0] - 1][y[0]];
ans += ch[1][x[0]][y[1]] - ch[1][x[0]][y[0] - 1];
ans += ch[2][x[1]][y[1]] - ch[2][x[0] - 1][y[1]];
ans += ch[3][x[1]][y[1]] - ch[3][x[1]][y[0] - 1];
ans += sum[x[1]][y[1]] - sum[x[0] - 1][y[1]] - sum[x[1]][y[0] - 1] + sum[x[0] - 1][y[0] - 1];
out(ans);enter;
} }
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
}

D - A or...or B Problem

找到\(A\)和\(B\)第一个不同的最高位是\(T = 2^{r}\)

然后只保留\(A\)和\(B\)的后\(r\)位

分成两个集合

\(\{A,A + 1....T - 1\}\)和\(\{T,T + 1...B\}\)

第一个集合能得到的数的区间是\([A,T - 1]\)

第二个集合除了第\(r\)位能得到的最高位是\(k\),能得到的区间为\([T,2^{r} + 2^{k + 1} - 1]\)

两个集合加一起能得到的区间是\([T + A,2T - 1]\)

区间求并即可

#include <bits/stdc++.h>
#define fi first
#define se second
#define pii pair<int,int>
#define mp make_pair
#define pb push_back
#define space putchar(' ')
#define enter putchar('\n')
#define eps 1e-10
#define MAXN 100005
//#define ivorysi
using namespace std;
typedef long long int64;
typedef unsigned int u32;
typedef double db;
template<class T>
void read(T &res) {
res = 0;T f = 1;char c = getchar();
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 +c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
pair<int64,int64> p[5];
void Solve() {
int64 A,B;
read(A);read(B);
if(A == B) {puts("1");return;}
int r = -1;
for(int i = 59 ; i >= 0 ; --i) {
if((A >> i & 1) != (B >> i & 1)) {r = i;break;}
}
int64 ans = 0;
A &= (1LL << r + 1) - 1;
B &= (1LL << r + 1) - 1;
p[1] = mp((1LL << r) + A,(1LL << r + 1) - 1);
int t = -1;
for(int i = r - 1 ; i >= 0 ; --i) {
if(B >> i & 1) {t = i;break;}
}
p[0] = mp(A,(1LL << r) + (1LL << t + 1) - 1);
sort(p,p + 2);
int64 rm = -1;
for(int i = 0 ; i < 2 ; ++i) {
if(p[i].se < rm) continue;
else {
ans += p[i].se - max(rm,p[i].fi - 1);
rm = p[i].se;
}
}
out(ans);enter;
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
}

E - Mr.Aoki Incubator

按照速度排序的话,如果选择一个点,能影响到的点是坐标值大于它且速度最小的到坐标值小于它且速度最大的点这个区间

这些区间排序后左右端点不降

然后可以用一个dp+前缀和统计一下覆盖全局的方案数

#include <bits/stdc++.h>
#define fi first
#define se second
#define pii pair<int,int>
#define mp make_pair
#define pb push_back
#define space putchar(' ')
#define enter putchar('\n')
#define eps 1e-10
#define MAXN 200005
//#define ivorysi
using namespace std;
typedef long long int64;
typedef unsigned int u32;
typedef double db;
template<class T>
void read(T &res) {
res = 0;T f = 1;char c = getchar();
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 +c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
const int MOD = 1000000007;
int N;
pii p[MAXN],rg[MAXN];
int L[MAXN],R[MAXN],st[MAXN],top;
int dp[MAXN],s[MAXN];
vector<int> v[MAXN];
int inc(int a,int b) {
return a + b >= MOD ? a + b - MOD : a + b;
}
int mul(int a,int b) {
return 1LL * a * b % MOD;
}
void update(int &x,int y) {
x = inc(x,y);
}
void Solve() {
read(N);
int x,v;
for(int i = 1 ; i <= N ; ++i) {
read(x);read(v);p[i] = mp(v,x);
}
sort(p + 1,p + N + 1); for(int i = 1 ; i <= N ; ++i) {
rg[i].fi = i;
if(!top || p[st[top]].se < p[i].se) st[++top] = i;
if(top) {
int l = 1,r = top;
while(l < r) {
int mid = (l + r) >> 1;
if(p[st[mid]].se >= p[i].se) r = mid;
else l = mid + 1;
}
rg[i].fi = st[l];
} }
top = 0;
for(int i = N ; i >= 1 ; --i) {
rg[i].se = i;
if(!top || p[st[top]].se > p[i].se) st[++top] = i;
if(top) {
int l = 1,r = top;
while(l < r) {
int mid = (l + r) >> 1;
if(p[st[mid]].se <= p[i].se) r = mid;
else l = mid + 1;
}
rg[i].se = st[l];
} }
sort(rg + 1,rg + N + 1);
s[0] = 1;dp[0] = 1;
int k = 1;
for(int i = 1 ; i <= N ; ++i) {
while(k <= rg[i].se) {
s[k] = inc(s[k - 1],dp[k]);
++k;
}
int t = s[rg[i].se];
if(rg[i].fi != 1) update(t,MOD - s[rg[i].fi - 2]);
update(dp[rg[i].se],t); s[rg[i].se] = inc(s[rg[i].se - 1],dp[rg[i].se]);
}
out(dp[N]);enter;
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
}

F结论题,看不懂,咕了

【AtCoder】AGC015的更多相关文章

  1. 【AtCoder】ARC092 D - Two Sequences

    [题目]AtCoder Regular Contest 092 D - Two Sequences [题意]给定n个数的数组A和数组B,求所有A[i]+B[j]的异或和(1<=i,j<=n ...

  2. 【Atcoder】CODE FESTIVAL 2017 qual A D - Four Coloring

    [题意]给定h,w,d,要求构造矩阵h*w满足任意两个曼哈顿距离为d的点都不同色,染四色. [算法]结论+矩阵变换 [题解] 曼哈顿距离是一个立着的正方形,不方便处理.d=|xi-xj|+|yi-yj ...

  3. 【AtCoder】ARC 081 E - Don't Be a Subsequence

    [题意]给定长度为n(<=2*10^5)的字符串,求最短的字典序最小的非子序列字符串. http://arc081.contest.atcoder.jp/tasks/arc081_c [算法]字 ...

  4. 【AtCoder】AGC022 F - Leftmost Ball 计数DP

    [题目]F - Leftmost Ball [题意]给定n种颜色的球各k个,每次以任意顺序排列所有球并将每种颜色最左端的球染成颜色0,求有多少种不同的颜色排列.n,k<=2000. [算法]计数 ...

  5. 【AtCoder】AGC005 F - Many Easy Problems 排列组合+NTT

    [题目]F - Many Easy Problems [题意]给定n个点的树,定义S为大小为k的点集,则f(S)为最小的包含点集S的连通块大小,求k=1~n时的所有点集f(S)的和取模92484403 ...

  6. 【AtCoder】ARC067 F - Yakiniku Restaurants 单调栈+矩阵差分

    [题目]F - Yakiniku Restaurants [题意]给定n和m,有n个饭店和m张票,给出Ai表示从饭店i到i+1的距离,给出矩阵B(i,j)表示在第i家饭店使用票j的收益,求任选起点和终 ...

  7. 【AtCoder】ARC095 E - Symmetric Grid 模拟

    [题目]E - Symmetric Grid [题意]给定n*m的小写字母矩阵,求是否能通过若干行互换和列互换使得矩阵中心对称.n,m<=12. [算法]模拟 [题解]首先行列操作独立,如果已确 ...

  8. 【Atcoder】AGC022 C - Remainder Game 搜索

    [题目]C - Remainder Game [题意]给定n个数字的序列A,每次可以选择一个数字k并选择一些数字对k取模,花费2^k的代价.要求最终变成序列B,求最小代价或无解.n<=50,0& ...

  9. 【Atcoder】AGC 020 B - Ice Rink Game 递推

    [题意]n个人进行游戏,每轮只保留最大的a[i]倍数的人,最后一轮过后剩余2人,求最小和最大的n,或-1.n<=10^5. [算法]递推||二分 [题解]令L(i),R(i)表示第i轮过后的最小 ...

随机推荐

  1. Linux中OCI开发库的配置

    Oracle调用接口(Oracle Call Interface,简称OCI)提供了一组可对Oracle数据库进行存取的接口子例程(函数),通过在第三代程序设计语言(如C语言)中进行调用可达到存取Or ...

  2. lua内存监测和回收

    以下来自书籍<Cocos2d-x之Lua核心编程> 1.----------------------------------------- 若想查看程序当前的内存占用情况,可以使用Lua提 ...

  3. R-CNN,SPP-NET, Fast-R-CNN,Faster-R-CNN, YOLO, SSD系列

    就是想保存下来,没有其他用意 原博文:http://blog.csdn.net/qq_26898461/article/details/53467968 3. 空间定位与检测     参考信息< ...

  4. Confluence 6 查看一个任务的执行历史

    希望查看一个计划任务最后运行的时间和这个计划任务最后一次运行花费了多长时间.单击计划任务边上的 历史(History )连接. 如果一个计划任务从来没有运行的胡啊,那么这个历史的链接是不会显示的. 屏 ...

  5. Confluence 6 恢复一个站点问题解决

    如果你在导入的时候遇到了问题,检查下面的一些提示. 你的文件太大而不能上传?这个是非常常见的错误.出现的原因是备份文件不能在规定的时间内上传到服务器上.为了避免这个错误,放置你的导出文件到  < ...

  6. Confluence 6 用户目录图例 - 连接 Jira

    上面的图:Confluence 连接到 JIRA 为用户管理. https://www.cwiki.us/display/CONFLUENCEWIKI/Diagrams+of+Possible+Con ...

  7. 用flask实现的分页

    一.flask实现的分页组件 from urllib.parse import urlencode,quote,unquote class Pagination(object): "&quo ...

  8. STL的基本操作指令

    list :Lists将元素按顺序储存在链表中. 与 向量(vectors)相比, 它允许快速的插入和删除,但是随机访问却比较慢. assign() 给list赋值 back() 返回最后一个元素 b ...

  9. 【python】给正则匹配部分命名

    可以用?P<name>的方法给正则匹配的部分命名. 例:要将<字母,数字>的部分命名为test x = "abc <haha,123> test @@&q ...

  10. 闭包&装饰器

    闭包 1.函数引用 def test(): print('--test--') # 调用函数 test() # 引用函数 ret = test print(id(ret)) print(id(test ...