AtCoder-arc060 (题解)
A - 高橋君とカード / Tak and Cards (DP)
题目大意:
有 \(n\) 个数字,要求取出一些数字,使得它们的平均数恰好为 \(x\) ,问有几种取法。
大致思路:
只要将每一个数字减掉 \(x\) ,那么问题就变成在 \(n\) 个数字中选取一些数字使得和为 \(0\) 的方案数,是一个经典的 \(dp\) 问题,不过要注意细节问题
代码:
展开查看代码
```c++
#include
#define ll long long
using namespace std;
const int N=5010;
const int Y=2500;
ll dp[N][N];
int n,x;
int a[N];
int main()
{
//freopen("H:\\c++1\\in.txt","r",stdin);
//freopen("H:\\c++1\\out.txt","w",stdout);
scanf("%d%d",&n,&x);
dp[0][Y]=1;
for(int i=1;i
B - 桁和 / Digit Sum (思维)
题目大意:
定义 \(f(n,b)\) 为 \(n\) 在 \(b\) 进制下各位数之和,现在给定 \(,n,s\) ,为求得最小的 \(b\) 使得 \(f(n,b)=s\)
\((n,s<=1e11)\)
大致思路:
这题很巧妙,首先如果答案 \(b\) 小于 \(1e6\) ,那么直接暴力枚举即可,若 \(b>1e6\) ,那么由于 \(n<=1e11\) ,那么 \(n\) 必然可以写成 \(n=kb+r\) ,且 \(s=k+r\) ,的形式, \(n-s=k(b-1)\) ,只要枚举 \(n-s\) 的因数即可解决,思维好题。
代码:
展开查看代码
```c++
#include
#define ll long long
using namespace std;
ll n,s;
bool check(ll x){
if(n/x>=x)return 0;
if(x>n>>s;
ll b=1e18;
if(n==s)b=n+1;
if(n>s){
ll temp=n-s;
for(ll t=1;t
C - 高橋君とホテル / Tak and Hotels (倍增)
题目大意:
水平轴上有 \(n\) 个点,每次跳不能超过 \(L\) ,每次必须跳在点上, \(Q\) 次询问,每次询问 \(,x,y\) ,表示从 \(x\) 到 \(y\) 最少需要跳几下。
大致思路:
感觉这题比较常见,是倍增的经典套路,用二分处理出 \(dp[i][0]\) ,跑一下预处理,然后就每次询问log查询就行了。
代码:
展开查看代码
```c++
#include
using namespace std;
const int N=1e5+10;
int dp[N][23];
int n,L;
int a[N];
int q,x,y;
int ef(int id,int v){
int l=id,r=n,ans=id;
while(l=0;i--){
if(dp[pos][i]y)swap(x,y);
printf("%d\n",js(x,y));
}
return 0;
}
```
D - 最良表現 / Best Representation (KMP)
题意大意:
定义一个字符串合法:当该字符串没有循环节存在,给出 \(string s\) ,令 \(F=(f_1,f_2..f_m)\) 满足 \(f_i\) 为 \(s\) 的某一部分. \(f_1,f_2,..f_m\) 连起来为 \(s\) .并且任意 \(f_i\) 为合法
\(|s|<=5e5\),求出 \(F\) 表示中最小的 \(m\) .并求出最小 \(m\) 的方案数?
大致思路:
这题感觉不难,只是由于是最后一题心理上有些畏惧,可惜了,首先先求出字符串的循环节,如果不存在循环节那么答案就是 \(1\ 1\) ,特判每一个字母都相同的情况答案为 \(len\ 1\) ,比较显然,那么我们可以确定剩下的字符串必然可以分成两个好串,那么我们只要枚举断点用 \(kmp\) 判断前面的字符串和后面的字符串是否为好串即可,代码实现也比较简单。
代码:
展开查看代码
```c++
#include
using namespace std;
const int N=5e5+10;
char s[N];
char s1[N];
int nxt[N],nxt1[N];//next数组
void kmp(char *t,int *nxt){//t为去匹配,s为被匹配
int i,j;
int len1=strlen(t+1);
nxt[0]=nxt[1]=0;
for(i=2,j=0;i
AtCoder-arc060 (题解)的更多相关文章
- AtCoder ExaWizards2019题解
AtCoder ExaWizards2019题解 AtCoder (因为代码直接用模板写的,可能有点冗长) A.Regular Triangle 给你三根棍子的长度,问你能否用他们组成等边三角形. 什 ...
- Atcoder ARC-060
ARC060(2020.7.8) A 背包板子 B 首先感觉这个东西应该不能直接 \(O(1)\) 算出来,那么复杂度应该就是 \(O(\log n), O(\sqrt{n}), O(\sqrt{n} ...
- KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解
KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解 哦淦我已经菜到被ABC吊打了. A - Century 首先把当前年 ...
- 【Atcoder ARC060F】最良表現 / Best Representation
Atcoder ARC060 F 题意:给一个串,求将其分成最少的没有循环节的串的种数. 思路:先求KMP的\(fail\)数组.然后发现最少的串数只有三种可能:\(1\).\(2\).\(n\). ...
- AT2370 Piling Up
https://www.luogu.org/jump/atcoder/2370 题解 答案不是\(2^{2m}\)因为每轮的第一次取球可能会不够. 我们可以设\(dp[i][j]\)表示到了第\(i\ ...
- Triple Shift
来源:Atcoder ARC 136 B - Triple Shift (atcoder.jp) 题解:这道题我们不可能去硬模拟(大多数这种题都不能这样去模拟的),然后我们就要去发现特性, 发现把 a ...
- 重修 Slope Trick(看这篇绝对够!)
Slope Trick 算法存在十余载了,但是我没有找到多少拍手叫好的讲解 blog,所以凭借本人粗拙的理解来写这篇文章. 本文除标明外所有图片均为本人手绘(若丑见谅),画图真的不容易啊 qwq(无耻 ...
- AtCoder Regular Contest 094 (ARC094) CDE题解
原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...
- AtCoder ExaWizards 2019 简要题解
AtCoder ExaWizards 2019 简要题解 Tags:题解 link:https://atcoder.jp/contests/exawizards2019 很水的一场ARC啊,随随便便就 ...
- AtCoder Grand Contest 017 题解
A - Biscuits 题目: 给出 \(n\) 个物品,每个物品有一个权值. 问有多少种选取方式使得物品权值之和 \(\bmod\space 2\) 为 \(p\). \(n \leq 50\) ...
随机推荐
- MySQL中列别名为中文时,Order by 子句中使用别名时不要加引号
暂时还不清楚原因 1.按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩 SC表: 这里,当做总成绩处理 select sid, sum(score) as '总成绩', avg(score) ...
- ESA2GJK1DH1K微信小程序篇: 测试微信小程序APUConfig给WI-Fi模块配网并绑定设备,并通过MQTT控制设备
前言(源码使用介绍在最后) 一,微信小程序篇小程序下载(该源码为这节测试源代码) 二.有多少人一直在期盼着小程序可以实现SmartConfig或者Airkiss的功能? 来吧!我的这种方式包您满意. ...
- [RN] React Native 再按一次退出
实现 React Native 再按一次退出 单页面: ... componentWillMount() { BackHandler.addEventListener('hardwareBackPre ...
- cf1189解题报告
cf1189div2解题报告 codeforces A 答案要不是一串要不就是去掉最后一个字母的两串 #include <bits/stdc++.h> #define ll long lo ...
- 如何让SublimeText3更好用
有关如何让Sublime Text3更好用 序言 某天在网上看到对于SublimeText3的介绍:一款插件功能强大的编辑器 ... 如果没有插件的话根本就是个稍微有点快捷键.配色喜人的普通编辑器,跟 ...
- A&G¥C015
A&G¥C015 A A+...+B Problem 正常A+B我还是会的,但是又加了个省略号就不会了/kk B Evilator 不会 C Nuske vs Phantom Thnook 以 ...
- 机器学习之决策树原理和sklearn实践
1. 场景描述 时间:早上八点,地点:婚介所 '闺女,我有给你找了个合适的对象,今天要不要见一面?' '多大?' '26岁' '长的帅吗?' '还可以,不算太帅' '工资高吗?' '略高于平均水平' ...
- Redis的内存回收策略和内存上限(阿里)
还有一篇文章 讲解guava如何删除过期数据的,与redis不同,guava没有维护线程删除过期key,只是在设置 key 或者 读取key的时候,顺带删除参考:GuavaCache简介(一)是轻量级 ...
- 《微信小程序商城开发实战》笔者的新书,欢迎各位粉丝上京东购买
作者图书京东链接,请点击------>>> **微信小程序商城开发实战** 附京东真实评价截图: 编辑推荐 在当今移动互联网大潮中,微信应用凭借其庞大的用户基数和极强的用户黏性 ...
- element UI中的select选择器的change方法需要传递多个值
如果直接调用change事件,不传任何参数,则可以获取到当前选中的值(因为默认会将event参数传递过去) 场景: 你需要将select选择器 ”选中的当前元素“ 和 ”其他你需要的值“ 一起传递过去 ...