ARC144
ARC 144
比赛情况:一眼订正,鉴定为做起 \(3\) 道题。
A - Digit Sum of 2x
\(2x\) 进位就不满足 \(M\) 最大的条件了,所以 \(x\) 不能进位。
然后要求 \(x\) 最小,只要 \(N\%4\neq 0\) 则最高位为 \(N\% 4\),否则最高位为 \(4\)。后面只能全填 \(4\) 了,因为这样位数最小。
点击查看代码
#include <bits/stdc++.h>
using namespace std;
const int MAXN=1e6+50;
int main()
{
int N;
cin>>N;
printf("%d\n",2*N);
if(N%4!=0)
printf("%d",N%4);
for(int i=1;i<=N/4;i++)
printf("4");
}
B - Gift Tax
贪心地看,要把最小的数弄大的同时把最大的数弄小。
有了贪心策略,就可以二分答案了,对于当前二分的答案,把 \(A\) 从小到大排序,双指针判一下就好。
点击查看代码
#include <bits/stdc++.h>
using namespace std;
const int MAXN=1e6+50;
int N;
int a,b;
int A[MAXN],B[MAXN];
bool Check(int Now)
{
for(int i=1;i<=N;i++)
{
B[i]=A[i];
}
int l=1,r=N;
long long Add=0;
while(l<r)
{
if(B[l]>=Now)
{
return true;
}
else
{
Add+=(Now-B[l]-1)/a+1;
while(Add&&l<r)
{
if(B[r]-Now>=Add*b)
{
B[r]-=Add*b;
Add=0;
break;
}
else
{
Add-=(B[r]-Now)/b;
r--;
}
}
}
l++;
}
if(Add)
{
return false;
}
else
{
return true;
}
}
int main()
{
scanf("%d%d%d",&N,&a,&b);
int l=1e9,r=0;
for(int i=1;i<=N;i++)
{
scanf("%d",&A[i]);
l=min(l,A[i]);
r=max(r,A[i]);
}
sort(A+1,A+N+1);
int Mid,ans=0;
while(l<=r)
{
Mid=l+r>>1;
if(Check(Mid))
{
ans=Mid;
l=Mid+1;
}
else
{
r=Mid-1;
}
}
cout<<ans;
}
C - K Derangement
考虑无解,只要存在一个值无论在哪里都放不了就无解。也就是 \(K>\lfloor \frac{N}{2} \rfloor\) 时无解。
假设 \(N\) 无穷大,那一定是每 \(2K\) 一个周期,这个周期内 \(A_i\) 的取值为 \(i+K\),\(A_{i+K}\) 的取值为 \(i\)。因为这能够让小的数被第一时间用掉,所以是最优的。
而事实上如果 \(N\) 不是 \(2K\) 的倍数,就会出问题,最后面会放不下。
所以最后预留一个整的长度为 \(2K\) 的段和剩下的长度为 \(N\%2K\) 的段。
对于这两个段,从后往前填,最大的几个数放在能放的最后一个位置。
剩下没放的位置,和剩下没用过的数字,越前面用越小的数字就行了。
点击查看代码
#include <bits/stdc++.h>
using namespace std;
const int MAXN=1e6+50;
int N,K;
int Ans[MAXN];
bool Use[MAXN];
priority_queue<int,vector<int>,greater<int> >q;
int main()
{
scanf("%d%d",&N,&K);
if(K>N/2)
{
puts("-1");
return 0;
}
for(int i=1;i<=N;i++)
{
q.push(i);
}
int Now=1;
for(;Now+(K<<1)<=N-(K<<1);Now+=(K<<1))
{
for(int i=Now;i<Now+K;i++)
{
Ans[i]=i+K;
Ans[i+K]=i;
Use[i]=Use[i+K]=true;
}
}
for(int i=Now;i<Now+K;i++)
{
Ans[i]=i+K;
Use[i+K]=true;
}
for(int i=N-(K<<1)+1;i<=N-K;i++)
{
Ans[i]=i+K;
Use[i+K]=true;
}
for(int i=1;i<=N;i++)
{
if(Ans[i]==0)
{
while(Use[q.top()])
q.pop();
Ans[i]=q.top();
q.pop();
}
printf("%d ",Ans[i]);
}
}
D - AND OR Equation
抛出一个结论:
\]
其中 \(i\in s\) 表示 \(s\) 二进制表示下第 \(i\) 位是 \(1\)。
按照题解的方法,令 \(c=f_0,g_i=f_{2^i}-c\)。
所以对于任意一组 \(\{c,g_0,...,g_{n-1}\}\) 都能构造出来一组 \(f\)。
所以原问题变成求有多少满足条件的上文所说的集合。
根据题意,\(0\leq c \leq K\)。
咕,明天继续写。
ARC144的更多相关文章
- ARC144 D - AND OR Equation
ARC144 D - AND OR Equation Solution 首先可以猜测和答案仅和每一个二进制位以及\(f(0)\)有关系,不妨把按位\(\operatorname{AND}\)和按位\( ...
- ARC145~152 题解
比赛标号从大到小排列 . 因为博主比较菜所以没有题解的题都是博主不会做的 /youl ARC144 以前的比赛懒得写了 . 目录 AtCoder Regular Contest 152 B. Pass ...
随机推荐
- 集合-TreeMap源码分析
一.简介 TreeMap最早出现在JDK 1.2中,是 Java 集合框架中比较重要一个的实现.TreeMap 底层基于红黑树实现,可保证在log(n)时间复杂度内完成 containsKey.get ...
- Wikijs简介-强大&可扩展的开源维基软件
Wikijs - 最强大 最可扩展的开源维基软件 使用 wiki.js 美丽直观的界面,让文档成为写作的乐趣! 优点 随时随地安装 几乎适用于任何平台,并与PostgreSQL.MySQL.Maria ...
- flask+gunicorn+nginx部署pytorch/python应用
1. 基于flask实现python服务Flask是一个使用 Python 编写的轻量级 Web 应用框架.其 WSGI 工具箱采用 Werkzeug ,模板引擎则使用 Jinja2 .Flask使用 ...
- pandas之reindex重置索引
重置索引(reindex)可以更改原 DataFrame 的行标签或列标签,并使更改后的行.列标签与 DataFrame 中的数据逐一匹配.通过重置索引操作,您可以完成对现有数据的重新排序.如果重置的 ...
- python之PySimpleGUI(二)属性
属性 Size• Key 相当于句柄/ID• Font• Pad• Colors• Enable Events• Visibility• Tooltip• Metadata• Right click ...
- [Java]排序算法>插入排序>【折半插入排序】(O(N*N)/稳定/N较大/无序/顺序存储)
1 折半插入排序 1.1 算法思想 相比于[直接插入排序]:采用"顺序查找法"查找当前记录在已排好序的序列中的插入位置, 折半插入排序利用"折半查找法"快速查出 ...
- 11.spring security 认证和授权简单流程了解
1.总结:昨天主要是对WebSecurityConfigurerAdaptor的三个函数的区分以及了解了spring security的认证和授权流程:再就是动手使用了下thymeleaf和freeM ...
- 9.springSecurity整合OAuth2结合Jwt实现单点登录
1.总结:昨天主要是继续完善OAuth2配合将问题完成单点登录,昨天也应证了一个认证服务,两个客户端服务在登陆一次后可以访问两个客户端的页面,也算是完成了单点登录 2.具体实现 首先是使用java ...
- Go语言核心知识回顾(接口、Context、协程)
温故而知新 接口 接口是一种共享边界,计算机系统的各个独立组件可以在这个共享边界上交换信息,在面向对象的编程语言,接口指的是相互独立的两个对象之间的交流方式,接口有如下好处: 隐藏细节: 对对象进行必 ...
- [Pytorch框架] 2.1.2 使用PyTorch计算梯度数值
文章目录 使用PyTorch计算梯度数值 Autograd 简单的自动求导 复杂的自动求导 Autograd 过程解析 扩展Autograd import torch torch.__version_ ...