Comet OJ - Contest #8
Comet OJ - Contest #8
A.杀手皇后
签到。
Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1005;
vector <string> v;
int n;
string s;
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n;
for(int i = 1; i <= n; i++) {
cin >> s;
v.push_back(s);
}
sort(v.begin(), v.end());
cout << v[0];
return 0;
}
B.支援城市
把式子拆开就行。
Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1e5 + 5;
int n;
int w[N];
ll sumv, sum;
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n;
for(int i = 1; i <= n; i++) cin >> w[i], sum += w[i];
for(int i = 1; i <= n; i++) sumv += 1ll * w[i] * w[i];
for(int i = 1; i <= n; i++) {
ll ans = sumv + 1ll * n * w[i] * w[i];
ans -= 2ll * w[i] * sum;
cout << ans << " \n"[i == n];
}
return 0;
}
C.符文能量
手玩一下样例,发现答案与合并顺序无关,然后就可以愉快的\(dp\)了。
因为最终序列的状态是有三个阶段的,所以就\(dp[i,0/1/2]\)来表示三种状态,然后分别转移就行。
Code
#include <bits/stdc++.h>
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
const int N = 1e5 + 5;
ll n, k;
ll a[N], b[N], c[N];
ll dp[N][3][2];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n >> k;
for(int i = 1; i <= n; i++) cin >> a[i] >> b[i];
for(int i = 1; i < n; i++) c[i] = a[i + 1] * b[i];
n--;
for(int i = 1; i <= n; i++) {
dp[i][0][0] = dp[i - 1][0][0] + c[i];
dp[i][0][1] = min(dp[i - 1][0][1], dp[i - 1][1][1]) + c[i];
dp[i][1][0] = dp[i - 1][0][0] + c[i] * k;
dp[i][1][1] = min(dp[i - 1][2][1], dp[i - 1][1][0]) + c[i] * k;
dp[i][2][1] = min(dp[i - 1][2][1], dp[i - 1][1][0]) + c[i] * k * k;
}
ll ans = INF;
ans = min(ans, min(dp[n][0][0], min(dp[n][0][1], min(dp[n][1][0], min(dp[n][1][1], dp[n][2][1])))));
cout << ans;
return 0;
}
还有一种前缀和的搞法,感觉说不太清楚,见代码吧:
Code
#include <bits/stdc++.h>
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
const int N = 1e5 + 5;
ll n, k;
ll a[N], b[N], c[N], d[N];
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n >> k;
for(int i = 1; i <= n; i++) cin >> a[i] >> b[i];
for(int i = 1; i < n; i++) c[i] = a[i + 1] * b[i], d[i] = d[i - 1] + c[i];
n--;
ll ans = min(d[n], d[n] * k * k), Min = 0;
for(int i = 1; i <= n; i++) {
ans = min(ans, c[i] * k + d[i - 1] * k * k + d[n] - d[i] + Min);
Min = min(Min, -d[i] * k * k + c[i] * k + d[i - 1]);
}
cout << ans;
return 0;
}
D.菜菜种菜
题目给出的询问都为连续的区间,考虑离线处理.
将题目所求转化为数学语言就是,对于一段区间[l,r],找到所有的点\(u\),满足对于所有的\((u,v)\),不存在\(v\in [l,r]\)。
那么我们就可以直接对于所有的点找到一个最大区间[L,R],表示在这个区间中,点\(u\)是不能到达任意点的,那么我们对于每个区间\([l,r]\),其中所有的点\(u\)对答案有贡献的话就会满足:\(L\leq l,r\leq R\)。
之后用树状数组进行增删查询的操作就行。
代码如下:
Code
#include <bits/stdc++.h>
#define MP make_pair
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
const int N = 1e6 + 5;
int n, m, q;
short a[N];
int l[N], r[N];
vector <pii> v[N];
vector <int> del[N];
int c[N];
int lowbit(int x) {return x & (-x);}
void update(int x, int v) {
for(; x < N; x += lowbit(x)) c[x] += v;
}
ll query(int x) {
ll ans = 0;
for(; x; x -= lowbit(x)) ans += c[x];
return ans;
}
int main() {
ios::sync_with_stdio(false); cin.tie(0);
cin >> n >> m >> q;
memset(r, INF, sizeof(r));
for(int i = 1; i <= n; i++) cin >> a[i];
for(int i = 1; i <= m; i++) {
int u, v; cin >> u >> v;
if(v < u) l[u] = max(l[u], v);
else r[u] = min(r[u], v);
}
for(int i = 1; i <= n; i++) {
l[i]++;
if(r[i] == INF) continue;
del[r[i]].push_back(i);
}
for(int i = 1; i <= q; i++) {
int L, R; cin >> L >> R;
v[R].push_back(MP(L, i));
}
ll ans = 0;
for(int i = 1; i <= n; i++) {
update(l[i], a[i]);
update(i + 1, -a[i]);
for(auto it : del[i]) {
update(l[it], -a[it]);
update(it + 1, a[it]);
}
for(auto it : v[i]) {
ans ^= 1ll * it.second * query(it.first);
}
}
cout << ans;
return 0;
}
Comet OJ - Contest #8的更多相关文章
- Comet OJ - Contest #2 简要题解
Comet OJ - Contest #2 简要题解 cometoj A 模拟,复杂度是对数级的. code B 易知\(p\in[l,r]\),且最终的利润关于\(p\)的表达式为\(\frac{( ...
- Comet OJ - Contest #2简要题解
Comet OJ - Contest #2简要题解 前言: 我没有小裙子,我太菜了. A 因自过去而至的残响起舞 https://www.cometoj.com/contest/37/problem/ ...
- Comet OJ - Contest #4--前缀和
原题:Comet OJ - Contest #4-B https://www.cometoj.com/contest/39/problem/B?problem_id=1577传送门 一开始就想着暴力打 ...
- Comet OJ - Contest #11 题解&赛后总结
Solution of Comet OJ - Contest #11 A.eon -Problem designed by Starria- 在模 10 意义下,答案变为最大数的最低位(即原数数位的最 ...
- Comet OJ - Contest #13-C2
Comet OJ - Contest #13-C2 C2-佛御石之钵 -不碎的意志-」(困难版) 又是一道并查集.最近做过的并查集的题貌似蛮多的. 思路 首先考虑,每次处理矩形只考虑从0变成1的点.这 ...
- Comet OJ - Contest #13 「火鼠的皮衣 -不焦躁的内心-」
来源:Comet OJ - Contest #13 芝士相关: 复平面在信息学奥赛中的应用[雾 其实是道 sb 题??? 发现原式貌似十分可二项式定理,然后发现确实如此 我们把 \(a^i\) 替换成 ...
- Comet OJ - Contest #13 「佛御石之钵 -不碎的意志-」(hard)
来源:Comet OJ - Contest #13 一眼并查集,然后发现这题 tmd 要卡常数的说卧槽... 发现这里又要用并查集跳过访问点,又要用并查集维护联通块,于是开俩并查集分别维护就好了 一开 ...
- Comet OJ - Contest #5
Comet OJ - Contest #5 总有一天,我会拿掉给\(dyj\)的小裙子的. A 显然 \(ans = min(cnt_1/3,cnt_4/2,cnt5)\) B 我们可以感性理解一下, ...
- Comet OJ Contest #13 D
Comet OJ Contest #13 D \(\displaystyle \sum_{i=0}^{\left\lfloor\frac{n}{2}\right\rfloor} a^{i} b^{n- ...
随机推荐
- Java编程思想——第17章 容器深入研究(一)
这一章将学习散列机制是如何工作的,以及在使用散列容器时怎么样编写hashCode()和equals()方法. 一.容器分类 先上两张图 来概况完整的容器分类 再细说都为什么会有那些特性. 二.Coll ...
- 【每天一题】LeetCode 0026. 删除排序数组中的重复项
开源地址:https://github.com/jiauzhang/algorithms 题目描述 /* * https://leetcode-cn.com/problems/remove-dupli ...
- Flask request和response
Response # -*- coding: utf-8 -*- from flask import Flask, redirect, render_template, jsonify, ...
- [转]企业创新平台—Power Platform 的架构与应用场景
本文转自:https://www.microsoft.com/china/events/video_311
- Android 监听手机锁屏的工具类
自定义 ScreenListener package com.example.teagardenhd.Listener; import android.content.BroadcastReceive ...
- 48-创建 overlay 网络
上一节我们搭建好实验环境,配置并运行了consul,今天开始创建 overlay 网络. 在 host1 中创建 overlay 网络 ov_net1: -d overlay 指定 driver 为 ...
- linux bash基础特性
使用history命令,取得命令历史,当bash进程结束后,会把命令历史存放到文件中,下次开机还能看到命令历史. 定制history:通过设置环境变量,来定制history 环境变量$HISTSIZE ...
- linux系统的特殊符号
符号 作用 示例 # 注释符号,井号后的内容不会执行 echo #WORD ~ 当前用户的家目录 cd ~ ; 命令顺序执行,前面执行成功与否对后面没影响 COMMAND1 ; COMMAND2 &a ...
- unittest---unittest的几种执行方法
我们在使用unittest单元测试框架做自动化的时候,可能会遇到想要看看这条用例写的是否正确,然后进行执行,但是又还有其他的用例在这里,我们又不能屏蔽,这个怎么办?不要着急unittest的几种执行方 ...
- gunicorn Python部署应用
对于flask应用 启动命令为 python app.py 使用gunicorn启动 pip install gunicorn python gunicorn --workers=7 switch_a ...