【AtCoder】 ARC 102
link
C-Triangular Relationship
发现要么全部是\(K\)的倍数,要么全部是模\(K\)余\(K/2,(K=2n)\)
#include<bits/stdc++.h>
#define ll long long
#define dbg1(x) cerr<<#x<<"="<<(x)<<" "
#define dbg2(x) cerr<<#x<<"="<<(x)<<"\n"
#define dbg3(x) cerr<<#x<<"\n"
using namespace std;
#define reg register
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
ll N,K,num;ll p3(ll x){return x*x*x;}
int main()
{
N=read();K=read();
num=p3(N/K);
if(K%2==0) num+=p3(N/K+((N%K)>=(K/2)));
printf("%lld\n",num);
}
D-All Your Paths are Different Lengths
\(L=2^{a_1}+2^{a_2}+...+2^{a_n},a_1<a_2<...<a_n\)
建立\(n\)个中转点,每个点\(i\)向下一个点连接\(0\)和\(2^{i-1}\)的边
对于\(a_i,i<n\),第\(a_i+1\)个点在向最后一个点连\(\sum_{j=i+1}2^{a_j}\)的边
#include<bits/stdc++.h>
#define ll long long
#define dbg1(x) cerr<<#x<<"="<<(x)<<" "
#define dbg2(x) cerr<<#x<<"="<<(x)<<"\n"
#define dbg3(x) cerr<<#x<<"\n"
using namespace std;
#define reg register
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
int L,a[25],cnt;
int main()
{
int L=read();
reg int i,j,N=0,M=0;
for(i=0;i<=20;++i)if(L>>i&1)a[++cnt]=i-1,++M;
N=a[cnt]+2;M=M+N*2-3;
printf("%d %d\n",N,M);
a[0]=-1;
for(i=1;i<=cnt;++i)
{
for(j=a[i-1];j<a[i];++j)
printf("%d %d %d\n",j+2,j+3,0),
printf("%d %d %d\n",j+2,j+3,(1<<(j+1)));
if(i==cnt) break;
printf("%d %d %d\n",a[i]+2,N,L-(1<<a[i]+1));
L-=1<<a[i]+1;
}
return 0;
}
E-Stop. Otherwise
比较简单的计数问题,一个限制相当于有两个数只能选择其中的一个
枚举一下选了多少个这样有限制的组,组合数算一下每个数要多少个
#include<bits/stdc++.h>
#define ll long long
#define dbg1(x) cerr<<#x<<"="<<(x)<<" "
#define dbg2(x) cerr<<#x<<"="<<(x)<<"\n"
#define dbg3(x) cerr<<#x<<"\n"
using namespace std;
#define reg register
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
const int Mod=998244353,MN=4004;
int Mul(int x,int y){return (1ll*x*y)%Mod;}
int Add(int x,int y){return (x+y)%Mod;}
int fac[MN],inv[MN],p2[MN];
int C(int i,int j)
{
if(i<0||j<0||i<j)return 0;
return Mul(fac[i],Mul(inv[j],inv[i-j]));
}
int F(int i,int j){return C(i+j-1,j-1);}
int sol(int N,int pr,int nm)
{
reg int i,j=min(N,pr);int r=0;
for(i=0;i<=j;++i)r=Add(r,Mul(p2[i],Mul(C(pr,i),F(N-i,nm-pr+i))));
return r;
}
int main()
{
int N,K;reg int i,Ma;
K=read();N=read();Ma=max(K,N);
for(fac[0]=i=1;i<=Ma*2;++i)fac[i]=Mul(fac[i-1],i);
for(inv[0]=inv[1]=1,i=2;i<=Ma*2;++i) inv[i]=Mul(inv[Mod%i],(Mod-Mod/i));
for(i=2;i<=Ma*2;++i) inv[i]=Mul(inv[i-1],inv[i]);
for(p2[0]=i=1;i<=Ma*2;++i) p2[i]=Mul(p2[i-1],2);
for(i=2;i<=K*2;++i)
{
int ans=0,pr=i/2-max(i-K,1)+1;
if(i%2==0) ans=Add(ans,sol(N-1,pr-1,K-pr));
ans=Add(ans,sol(N,pr-(i%2==0),K-pr));
printf("%d\n",ans);
}
return 0;
}
F-Revenge of BBuBBBlesort
考虑逆操作的过程
发现\(i-1,i,i+1\)一旦交换过,\(i\)这个点就不会变了
最后,每个有变化的极大区间\([i,j]\)一定满足
- \(i,i+2,i+4,...j\)的位置变化
- \(i+1,i+3,i+5,...j-1\)的位置不变
我们找到这样一个区间,又因为它无法与周围的其它的数交换,所以这个区间的值的集合应该恰好等于这个区间的每个位置下标的集合
考虑怎样才能移动为有序
首先,如果将一个数向右移动,那么它无法再向左移动,因为与它相邻的数是固定的,所以无法往回走
所以,一个数能朝着它的目标位置方向做单向运动
朝同一个方向运动的数单调递增,否则超越的那一步,前数朝反方向运动
相当于\(a[i]<i\)和\(a[i]>i\)的点的\(a[i]\)值分别单调递增
#include<bits/stdc++.h>
#define ll long long
#define dbg1(x) cerr<<#x<<"="<<(x)<<" "
#define dbg2(x) cerr<<#x<<"="<<(x)<<"\n"
#define dbg3(x) cerr<<#x<<"\n"
using namespace std;
#define reg register
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
}
const int MN=300005;
int a[MN],N;
void No(){puts("No");exit(0);}
void Yes(){puts("Yes");exit(0);}
void chk(int l,int r)
{
reg int i,_1=0,_2=0;
for(i=l+1;i<=r-1;i+=2)if(a[i]!=i)No();
for(i=l;i<=r;i+=2)if(a[i]==i)No();
for(i=l;i<=r;i+=2)
if(i<a[i]){if(_1>a[i])No();_1=a[i];}
else{if(_2>a[i])No();_2=a[i];}
}
main()
{
N=read();reg int i;
for(i=1;i<=N;++i) a[i]=read();
int l=1,r;
while(a[l]==l&&l<N)++l;
while(1)
{
if(a[l]==l)Yes();
if(l+2>N)No();r=l+2;
int Mi=min(a[l],a[r]),Ma=max(a[l],a[r]);
while((r!=Ma||l!=Mi)&&r<=N)r+=2,Mi=min(Mi,a[r]),Ma=max(Ma,a[r]);
if(r>N)No();chk(l,r);
l=r+1;while(a[l]==l&&l<N)++l;
if(l>N)break;
}
Yes();
}
Blog来自PaperCloud,未经允许,请勿转载,TKS!
【AtCoder】 ARC 102的更多相关文章
- 【AtCoder】ARC 081 E - Don't Be a Subsequence
[题意]给定长度为n(<=2*10^5)的字符串,求最短的字典序最小的非子序列字符串. http://arc081.contest.atcoder.jp/tasks/arc081_c [算法]字 ...
- 【Atcoder】ARC 080 E - Young Maids
[算法]数学+堆 [题意]给定n个数的排列,每次操作可以取两个数按序排在新序列的头部,求最小字典序. [题解] 转化为每次找字典序最小的两个数按序排在尾部,则p1和p2的每次选择都必须满足:p1在当前 ...
- 【Atcoder】ARC 080 F - Prime Flip
[算法]数论,二分图最大匹配 [题意]有无限张牌,给定n张面朝上的牌的坐标(N<=100),其它牌面朝下,每次操作可以选定一个>=3的素数p,并翻转连续p张牌,求最少操作次数使所有牌向下. ...
- 【AtCoder】 ARC 097
link C-K-th Substring 题意:找出已知串中第\(k\)大的子串,子串相同的不算 \(k\)好小啊,要怎么做啊 不是[Tjoi2015]弦论吗 算了,直接SAM吧 #include& ...
- 【AtCoder】 ARC 096
link C-Half and Half 题意:三种pizza,可以花\(A\)价钱买一个A-pizza,花\(B\)价钱买一个B-pizza,花\(C*2\)价钱买A-pizza和B-pizza各一 ...
- 【AtCoder】 ARC 098
link C-Attention 题意:一个字符队列,每个位置是\(W\)或\(E\),计算最小的修改数量,使得存在一个位置,它之前的都是\(E\),之后的都是\(F\) #include<bi ...
- 【AtCoder】 ARC 099
link C-Minimization 枚举覆盖\(1\)的区间,两边的次数直接算 #include<bits/stdc++.h> #define ll long long #define ...
- 【AtCoder】 ARC 100
link C-Linear Approximation 给出\(N\)个数\(A_1,A_2,...,A_N\) ,求一个数\(d\),最小化\(\sum_{i=1}^N|A_i-(d+i)|\) 把 ...
- 【AtCoder】 ARC 101
link 搬来了曾经的题解 C-Candles 题意:数轴上有一些点,从原点开始移动到达这些点中的任意\(K\)个所需要的最短总路程 \(K\)个点必然是一个区间,枚举最左边的就行了 #include ...
随机推荐
- 爬虫多次爬取时候cookie的存储用于登入
一.用requests模块自动保存(保存缓存中) 构建一个session对象session = requests.session() 用构建的session代替requests进行访问他就会自动存啦 ...
- 线程并发工具类之CountDownLatch的使用及原理分析
原文链接:http://www.studyshare.cn/blog/details/1149/1 java开发工具下载地址及安装教程大全,点这里.更多技术文章,在这里. 一.定义 CountDown ...
- Java自学-类和对象 继承
什么是 Java的 继承 ? 在LOL中,武器是物品的一种,也是有名称和价格的 所以在设计类的时候,可以让武器继承物品,从而继承名称和价格属性 步骤 1 : 物品类Item 物品类Item 有属性 n ...
- 【转载】C#中List集合使用AddRange方法将一个集合加入到指定集合末尾
C#编程开发过程中,List集合是时常使用到的集合对象,如果在List集合的操作中需要将1个List集合加入到另一个List集合的末尾,则可以使用List集合的AddRange方法来实现,AddRan ...
- JQuey中ready()的4种写法
在jQuery中,对于ready()方法,共有4种写法: (1)写法一: $(document).ready(functin(){ //代码部分 }) 分析:这种代码形式是最常见的,其中$(docum ...
- Oracle 逻辑存储结构
一.总述 逻辑存储结构是 Oracle 数据库存储结构的核心内容,对 Oracle 数据库的所有操作都会涉及逻辑存储结构.逻辑存储结构是从逻辑的角度分析数据库的组成,是对数据存储结构在逻辑概念上的划分 ...
- 用java语言将数据库中的数据表转换为xml文件的通用程序(细化)
转自:https://www.cnblogs.com/wudage/p/7650685.html 总是在网络上copy别人的源代码,今天我也贴出自己今天写的源码,相信这个程序会对大家在平时的工作中需要 ...
- js计算两个时间差 天 时 分 秒 毫秒
// 计算两个时间差 dateBegin 开始时间 function timeFn(dateBegin) { //如果时间格式是正确的,那下面这一步转化时间格式就可以不用了 var dateEnd = ...
- beta版本——第五次冲刺
第五次冲刺 (1)SCRUM部分☁️ 成员描述: 姓名 李星晨 完成了哪个任务 界面优化 花了多少时间 2h 还剩余多少时间 2h 遇到什么困难 没有 这两天解决的进度 2/2 后续两天的计划 完成文 ...
- django项目基于钩子验证的注册功能
前端html <div class="agile-row"> <h3>注册</h3> {# 注册的开始#} <div class=&quo ...