Codeforces Round #716 (Div. 2) A ~ D 个人题解
补题链接:Here
1514A. Perfectly Imperfect Array
题意:给定长度为 \(n\) 的 \(a\) 序列,请问是否存在子序列积不存在平方根
思路:子序列的话,一个元素也是子序列,那么只要存在某个元素不存在平方根即可
void solve() {
int n;
cin >> n;
bool f = 1;
while (n--) {
int x, tmp;
cin >> x;
tmp = sqrt(x);
if (tmp * tmp != x) f = 0;
}
cout << (!f ? "YES\n" : "NO\n");
}
1514B. AND 0, Sum Big
题面解释了那么多,本质就是
qpow(n,k) % mod
using ll = long long;
const int mod = 1e9 + 7;
ll qpow(ll a, ll b) {
ll ans = 1;
a %= mod;
for (; b; b >>= 1, a = a * a % mod)
if (b & 1) ans = ans * a % mod;
return ans;
}
void solve() {
ll n, k;
cin >> n >> k;
cout << qpow(n, k) << "\n";
}
1514C. Product 1 Modulo N
题意:
现在,您得到Baby Ehab的第一句话:“给定整数n,找到乘积为1模n的最长子序列 \([1,2,…,n-1]\)。” 请解决问题。
如果可以通过删除某些(可能是全部)元素从a获得b,则序列b是数组a的子序列。 空子序列的乘积等于1。
思路:
首先想到 \(n = 2\) 时,仅有一种情况就是 \(1\)
然后在考虑 \(2\le n\) 时,维护 \(ans\) 。如果 \(i\) 与 \(ans\) 互质则可以加入序列。
最后如果 \(ans = n - 1\) 最后一个数肯定不符合需要删去
int n;
void solve() {
cin >> n;
if (n == 2) {
cout << "1\n1";
return;
}
ll ans = 1;
vector<int> v;
for (int i = 1; i <= n; ++i) {
if (__gcd(n, i) == 1) {
v.push_back(i);
ans = ans * i % n;
}
}
if (ans == n - 1) v.pop_back();
cout << v.size() << "\n";
for (int x : v) cout << x << " ";
}
1514D. Cut and Stick
涉及区间修改查询问题肯定是线段树(树状数组)了
#include <bits/stdc++.h>
using namespace std;
using LL = long long;
constexpr LL mod = 1000000007;
constexpr int maxn = 300000 + 1;
struct Node {
int cur, cnt;
Node operator*(const Node &p) const {
if (cur == p.cur) return {cur, cnt + p.cnt};
if (cnt >= p.cnt) return {cur, cnt - p.cnt};
return {p.cur, p.cnt - cnt};
}
} t[maxn << 2];
int a[maxn];
vector<int> p[maxn];
#define ls (v << 1)
#define rs (ls | 1)
#define tm ((tl + tr) >> 1)
void build(int v, int tl, int tr) {
if (tl == tr)
t[v] = {a[tm], 1};
if (tl < tr) {
build(ls, tl, tm);
build(rs, tm + 1, tr);
t[v] = t[ls] * t[rs];
}
}
Node query(int v, int tl, int tr, int L, int R) {
if (tl >= L and tr <= R) return t[v];
Node res = {0, 0};
if (L <= tm) res = res * query(ls, tl, tm, L, R);
if (R > tm) res = res * query(rs, tm + 1, tr, L, R);
return res;
}
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n, q;
cin >> n >> q;
for (int i = 1; i <= n; i += 1) cin >> a[i];
for (int i = 1; i <= n; i += 1) p[a[i]].push_back(i);
build(1, 1, n);
for (int i = 1; i <= q; i += 1) {
int L, R;
cin >> L >> R;
auto v = query(1, 1, n, L, R);
int x = R - L + 1;
int y = v.cur;
int z = upper_bound(p[y].begin(), p[y].end(), R) - lower_bound(p[y].begin(), p[y].end(), L);
cout << max(2 * z - x, 1) << "\n";
}
return 0;
}
Codeforces Round #716 (Div. 2) A ~ D 个人题解的更多相关文章
- Codeforces Round #609 (Div. 2)前五题题解
Codeforces Round #609 (Div. 2)前五题题解 补题补题…… C题写挂了好几个次,最后一题看了好久题解才懂……我太迟钝了…… 然后因为longlong调了半个小时…… A.Eq ...
- Codeforces Round #716 (Div. 2), problem: (B) AND 0, Sum Big位运算思维
& -- 位运算之一,有0则0 原题链接 Problem - 1514B - Codeforces 题目 Example input 2 2 2 100000 20 output 4 2267 ...
- Codeforces Round #556 (Div. 2) D. Three Religions 题解 动态规划
题目链接:http://codeforces.com/contest/1150/problem/D 题目大意: 你有一个参考串 s 和三个装载字符串的容器 vec[0..2] ,然后还有 q 次操作, ...
- Codeforces Round #604 (Div. 2) E. Beautiful Mirrors 题解 组合数学
题目链接:https://codeforces.com/contest/1265/problem/E 题目大意: 有 \(n\) 个步骤,第 \(i\) 个步骤成功的概率是 \(P_i\) ,每一步只 ...
- Codeforces Round #624 (Div. 3) F. Moving Points 题解
第一次写博客 ,请多指教! 翻了翻前面的题解发现都是用树状数组来做,这里更新一个 线段树+离散化的做法: 其实这道题是没有必要用线段树的,树状数组就能够解决.但是个人感觉把线段树用熟了会比树状数组更有 ...
- Codeforces Round #677 (Div. 3) E、G题解
E. Two Round Dances #圆排列 题目链接 题意 \(n\)(保证偶数)个人,要表演一个节目,这个节目包含两种圆形舞蹈,而每种圆形舞蹈恰好需要\(n/2\)个人,每个人只能跳一种圆形舞 ...
- Codeforces Round#402(Div.1)掉分记+题解
哎,今天第一次打div1 感觉头脑很不清醒... 看到第一题就蒙了,想了好久,怎么乱dp,倒过来插之类的...突然发现不就是一道sb二分吗.....sb二分看了二十分钟........ 然后第二题看了 ...
- Codeforces Round #604 (Div. 2) 练习A,B题解
A题 链接 思路分析: 因为只需要做到相邻的不相同,利用三个不同的字母是肯定可以实现的, 所以直接先将所有的问号进行替换,比如比前一个大1,如果与后面的冲突,则再加一 代码(写的很烂): #inclu ...
- Codeforces Round #599 (Div. 2)的简单题题解
难题不会啊…… 我感觉写这个的原因就是因为……无聊要给大家翻译题面 A. Maximum Square 简单题意: 有$n$条长为$a_i$,宽为1的木板,现在你可以随便抽几个拼在一起,然后你要从这一 ...
- Codeforces Round #635 (Div. 2)部分(A~E)题解
虽然打的是div1,但最后半小时完全处于挂机状态,不会做1C,只有个 \(O(n^3)\) 的想法,水了水论坛,甚至看了一下div2的AB,所以干脆顺便写个div2的题解吧,内容看上去还丰富一些(X) ...
随机推荐
- springboot实现反向代理,动态代理目标地址
网上找了很多文章,各种照搬,只能自己实现 基于开源项目HTTP-Proxy-Servlet实现 开源项目地址:https://github.com/mitre/HTTP-Proxy-Servlet 1 ...
- 吉特日化MES & RabbitMQ 的基本配置
在吉特日化MES(日化配料系统)中涉及到大量的消息推送,其中针对设备数据的交互(读写) 大量使用了RabbitMQ来进行消息通讯以及程序上的解耦,其中包含使用PDA扫码登录到PLC控制程序,下发生产工 ...
- 聊一聊 .NET高级调试 中必知的符号表
一:背景 1. 讲故事 在高级调试的旅行中,发现有不少人对符号表不是很清楚,其实简而言之符号表中记录着一些程序的生物特征,比如哪个地址是函数(签名信息),哪个地址是全局变量,静态变量,行号是多少,数据 ...
- Hnswlib 介绍与入门使用
Hnswlib是一个强大的近邻搜索(ANN)库, 官方介绍 Header-only C++ HNSW implementation with python bindings, insertions a ...
- python、numpy计算不同文档下的词的TF-IDF值以及进行文档相似度匹配(实战)
TF-IDF 计算公式(一个词的 tf-idf 值在不同文档,它的值也不同): 1.根据已有的原始数据,只展示了前5片文档,content是文档内容,s_words是通过jieba分词将文档划分成了若 ...
- Ruby 版本升级
一.升级原因 在开发shopify app的时候,提示我当前的Ruby版本不支持(如下图),所以需要升级Ruby. 由于Ruby 中的一些 Gem 依赖于 OpenSSL 库,所以更改 Ruby 版本 ...
- Android SDK Manager 报错“加载 SDK 组件信息失败”。(Android SDK Manager complains with "Loading SDK component information failed."
[解决方案]: 将存储库设置更改为 Google .因此,在 android SDK 管理器上点击齿轮图标(设置),然后点击 Repository -> Google.
- CentOS7 安装Python3.9以上版本时。编译报错,原因是openssl版本低
openssl-1.1.1安装 1.前因 python 导入clickhouse_driver需要import ssl和_ssl,报错 File"/home/oracle/python3/l ...
- MySQL|空间碎片化问题处理
一.空间碎片化严重案例分享 1.1 问题描述 实例磁盘空间近1个月上涨趋势明显,主要是个别日志表存储较大且部分表存在空间碎片化的现象. 1.2 处理流程 1.通过日常巡检以及监控发现某实例磁盘空间近1 ...
- 云MSP技本功|redis的5种对象与8种数据结构之字符串对象(下)
简介: 引言 本文是对<redis设计与实现(第二版)>中数据结构与对象相关内容的整理与说明.本篇文章只对对象结构,1种对象--字符串对象.以及字符串对象所对应的两种编码--raw和emb ...