A.很水的题目,3个for循环就可以了

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
char str[];
int main()
{
cin>>str;
int ans = ;
int L = strlen(str);
for(int i = ; i < L; i++)
for(int j = i+; j < L; j++)
for(int k = j+; k < L; k++)
if(str[i] == 'Q' && str[j] == 'A' && str[k] == 'Q') ans++;
cout<<ans<<endl;
return ;
}

B.如果存在解,那么答案就是2^(x-1)(y-1),然后快速幂就可以了。

实际上就是判断(x-1)*(y-1)都填1有没有解,如果有的话,其实你变换任意一个矩阵内元素的值都有对应的唯一一种情况成立。

注意费马小定理和long long的溢出问题。

#include <iostream>
#include <cstdio>
using namespace std;
typedef long long LL;
const LL MOD = 1e9 + ;
LL mypow(LL a, LL b){
LL ans = ; for(; b; b>>=, (a*=a)%=MOD) if(b&) (ans*=a)%=MOD;return ans;
}
LL x, y, k;
int main()
{
cin>>x>>y>>k;
if( ((x+y)&) && k == -){
cout<<<<endl;
return ;
}
cout<<mypow(, ((x-)%(MOD-)) *((y-)%(MOD-)) %(MOD-))<<endl;
return ;
}

C.首先必定有一个元素是所有元素的gcd,否则就是无解。

然后这个gcd也必定是最小的,令它为g,那么我们只需要把g插入到原序列中,就可以保证两两之间的gcd被限制到g,就满足了要求。

这个构造还是挺巧妙的。

#include <iostream>
#include <cstdio>
using namespace std;
const int maxn = ;
int a[maxn], n;
int H[];
int gcd(int x, int y) { return x % y == ? y : gcd(y, x%y); }
int main()
{
cin>>n;
for(int i = ; i <= n; i++) scanf("%d", &a[i]);
int ans = a[];
for(int i = ; i <= n; i++) ans = gcd(ans, a[i]);
if(ans != a[]){
cout<<"-1"<<endl;
return ;
}
cout<<*n-<<endl;
cout<<a[]<<" ";
for(int i = ; i <= n; i++){
cout<<a[]<<" "<<a[i]<<" ";
}
}

D.树是二叉树,就很好做了

每个结点保存子树中到它的距离集合

答案就是子树内满足要求的点的个数n*h和它们的距离和的差,就是n*h - sum

查询这个用二分查找就可以了

注意到非子树内也有满足要求的点,

解决这个问题只需要沿着祖先往上爬就可以了,沿途统计答案。

这里使用了upper_bound,还是很好用的。

#include <iostream>
#include <cstring>
#include <cstdio>
#include <vector>
#include <algorithm>
using namespace std;
const int maxn = 1e6 + ;
long long v[maxn][];
vector<long long> D[maxn], Sum[maxn];
long long getsum(int k, int i, int j){
if(i > j) return ;
return i- < ? Sum[k][j] : Sum[k][j] - Sum[k][i-];
}
int main()
{
int n, m, x, a, h;
cin>>n>>m;
for(int i = ; i < n; i++) {
scanf("%d", &x);
v[(i+)/][(i+)%] = x;
}
for(int i = n; i >= ; i--){
D[i].push_back();
if(i* <= n){
for(auto x : D[i*])
D[i].push_back(x+v[i][]);
}
if(i*+ <= n){
for(auto x : D[i*+])
D[i].push_back(x+v[i][]);
}
sort(D[i].begin(), D[i].end());
Sum[i].push_back(D[i][]);
for(int j = ; j < D[i].size(); j++) Sum[i].push_back(D[i][j]+Sum[i][j-]);
}
while(m--){
scanf("%d %d", &a, &h);
long long d = , n = , decans = ;
int pos1 = upper_bound(D[a].begin(), D[a].end(), h) - D[a].begin();
n += pos1;
decans += getsum(a, , pos1-);
int i = a, j;
while(i != ){
j = i^;
d += v[i/][i&];
if(d < h) {
n++;
decans += d;
}
i /= ;
pos1 = upper_bound(D[j].begin(), D[j].end(), h-v[i][j&]-d) - D[j].begin();
n += pos1;
decans += getsum(j, , pos1-)+pos1*(d+v[i][j&]);
}
long long ans = (long long)n*h - decans;
printf("%lld\n", ans);
}
}

E.就是tarjan缩点+动态规划。

缩点之后可以用dfs直接更新dp。

注意要先求最大值,再加环构成的影响。

求一个边的循环贡献,这里是先排了个序,然后按顺序扫一遍求出来的。

当然也可以二分找。

#include <iostream>
#include <cstdio>
#include <stack>
#include <vector>
#include <queue>
#include <algorithm>
#define mp make_pair
#define fi first
#define se second
using namespace std;
const int maxn = 1e6 + ;
stack<int> S;
vector< pair<int, int> > G2[maxn];
vector<int> G[maxn];
long long dp[maxn], v[maxn];
int dfn[maxn], low[maxn], ins[maxn], bl[maxn], C = , Z = ;
int vis[maxn];
void tj(int x)
{
dfn[x]=low[x]=++C; ins[x]=; S.push(x);
for(auto b : G[x])
{
if(!dfn[b]) tj(b),low[x]=min(low[x],low[b]);
else if(ins[b]) low[x]=min(low[x],dfn[b]);
}
if(dfn[x]!=low[x]) return;
++Z;
while(!S.empty())
{
int g=S.top(); S.pop();
ins[g]=; bl[g]=Z;
if(g==x) break;
}
}
struct Edge{
int from, to, cost;
Edge(int from, int to, int cost):from(from), to(to), cost(cost) {}
bool operator <(const Edge &B) const{
return cost < B.cost;
}
};
vector<Edge> edges;
int n, m, x, y, z, s;
long long ans = ;
void dfs(int x){
if(vis[x]) return;
vis[x] = ; dp[x] = ;
for(auto e : G2[x]){
dfs(e.fi);
dp[x] = max(dp[x], dp[e.fi] + e.se);
}
dp[x] += v[x];
ans = max(ans, dp[x]);
}
int main()
{
cin>>n>>m;
for(int i = ; i <= m; i++){
scanf("%d %d %d", &x, &y, &z);
G[x].push_back(y);
edges.push_back(Edge(x, y, z));
}
sort(edges.begin(), edges.end());
cin>>s;
tj(s);
int k = ;
for(auto &e : edges){
while(e.cost >= (k+)*(k+)/) k++;
long long temp = (long long)e.cost*(k+) - (long long)k*(k+)*(k+)/;
if(bl[e.from] == bl[e.to])
v[bl[e.from]] += temp;
else G2[bl[e.from]].push_back(mp(bl[e.to], e.cost));
}
dfs(bl[s]);
cout<<ans<<endl;
return ;
}

Codeforces Round #447 (Div. 2) 题解的更多相关文章

  1. Codeforces Round #447 (Div. 2) 题解 【ABCDE】

    BC都被hack的人生,痛苦. 下面是题解的表演时间: A. QAQ "QAQ" is a word to denote an expression of crying. Imag ...

  2. Codeforces Round #182 (Div. 1)题解【ABCD】

    Codeforces Round #182 (Div. 1)题解 A题:Yaroslav and Sequence1 题意: 给你\(2*n+1\)个元素,你每次可以进行无数种操作,每次操作必须选择其 ...

  3. Codeforces Round #608 (Div. 2) 题解

    目录 Codeforces Round #608 (Div. 2) 题解 前言 A. Suits 题意 做法 程序 B. Blocks 题意 做法 程序 C. Shawarma Tent 题意 做法 ...

  4. Codeforces Round #525 (Div. 2)题解

    Codeforces Round #525 (Div. 2)题解 题解 CF1088A [Ehab and another construction problem] 依据题意枚举即可 # inclu ...

  5. Codeforces Round #528 (Div. 2)题解

    Codeforces Round #528 (Div. 2)题解 A. Right-Left Cipher 很明显这道题按题意逆序解码即可 Code: # include <bits/stdc+ ...

  6. Codeforces Round #466 (Div. 2) 题解940A 940B 940C 940D 940E 940F

    Codeforces Round #466 (Div. 2) 题解 A.Points on the line 题目大意: 给你一个数列,定义数列的权值为最大值减去最小值,问最少删除几个数,使得数列的权 ...

  7. Codeforces Round #677 (Div. 3) 题解

    Codeforces Round #677 (Div. 3) 题解 A. Boring Apartments 题目 题解 简单签到题,直接数,小于这个数的\(+10\). 代码 #include &l ...

  8. Codeforces Round #665 (Div. 2) 题解

    Codeforces Round #665 (Div. 2) 题解 写得有点晚了,估计都官方题解看完切掉了,没人看我的了qaq. 目录 Codeforces Round #665 (Div. 2) 题 ...

  9. Codeforces Round #160 (Div. 1) 题解【ABCD】

    Codeforces Round #160 (Div. 1) A - Maxim and Discounts 题意 给你n个折扣,m个物品,每个折扣都可以使用无限次,每次你使用第i个折扣的时候,你必须 ...

随机推荐

  1. day5 if while for

    .注意点: ctrl + n 自动补全 18行报错,直接定位18行 逻辑运算符and or not 复合赋值运算符 += .if-elif 判断星期几 猜拳游戏 .while循环 )3大执行流程 )什 ...

  2. LVS入门篇(五)之LVS+Keepalived实战

    一.实验架构和环境说明 (1)本次基于VMware Workstation搭建一个四台Linux(CentOS 7.4)系统所构成的一个服务器集群,其中两台负载均衡服务器(一台为主机,另一台为备机), ...

  3. Maven学习(十五)-----Maven常用命令

    一.Maven常用命令 1.1.Maven 参数 -D 传入属性参数  -P 使用pom中指定的配置  -e 显示maven运行出错的信息  -o 离线执行命令,即不去远程仓库更新包  -X 显示ma ...

  4. Springboot 配置实现定时任务

    善于思考,拥抱变化,才能拥有未来 在springboot项目中可以通过配置文件来实现定时任务的轮询,当然也可以将具体执行的corn表达式配置到数据库,实现动态从数据库获取. @Configuratio ...

  5. 第五篇 Postman离线安装interceptor插件---Chrome app及录制请求

    在测试中,总是苦恼于无法直接使用chrome浏览器的cookie等信息,终于在茫茫网海中,发现了 https://www.jianshu.com/p/a4223bab1e73, 感谢 智者向内寻求力量 ...

  6. 电脑提示‘您需要来自Administration的权限才能对此文件夹进行更改’怎么删除文件

    电脑提示'您需要来自Administration的权限才能对此文件夹进行更改'怎么删除文件 应该怎么做 win7系统需要定期删除一些无用的文件,扩大内存空间,但是在删除文件的时候弹出提示"您 ...

  7. Beta发布——视频博客

    1.视频链接 视频上传至优酷自频道,地址链接:http://v.youku.com/v_show/id_XMzkzNzAxNDk2OA==.html?spm=a2hzp.8244740.0.0 2.视 ...

  8. .net web 应用程序C#

    简介 开发环境:VS2015 ASP.NET:可以开发出几乎所有运行在Windows上的应用程序:.NET是一种架构,一种新的API:引入程序集代替DLL: ADO.NET:一组.NET组件提供对数据 ...

  9. c++第三次作业

    GitHub地址 https://github.com/ronghuijun/3Elevators-scheduling 实现过程 一开始打算分成三个类来写的 因为想到电梯的功能不太一样 一个只能上1 ...

  10. springboot+vue+element:echarts开发遇见问题---后端sql(三)

    <select id="getSumRequestRankingCount" parameterType="java.lang.String" resul ...