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

抛出一个结论:

\[f_s=f_0+\sum_{i\in s}(f_{2^i}-f_0)
\]

其中 \(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的更多相关文章

  1. ARC144 D - AND OR Equation

    ARC144 D - AND OR Equation Solution 首先可以猜测和答案仅和每一个二进制位以及\(f(0)\)有关系,不妨把按位\(\operatorname{AND}\)和按位\( ...

  2. ARC145~152 题解

    比赛标号从大到小排列 . 因为博主比较菜所以没有题解的题都是博主不会做的 /youl ARC144 以前的比赛懒得写了 . 目录 AtCoder Regular Contest 152 B. Pass ...

随机推荐

  1. openfoam并行通信探索(一)

    前言 最近在忙,快一两周没更新了,今天说下如何实现openfoam内的并行通信 为什么要并行通信 说到并行通信大家不要害怕啊,只是不同核之间数据传递,比如说咱们仿真开16个核,3号计算单元对4号计算单 ...

  2. Python爬取爬取明星关系并写入csv文件

    今天用Python爬取了明星关系,数据不多,一共1386条数据,代码如下: import requests from bs4 import BeautifulSoup import bs4 impor ...

  3. 集合-LinkedList 源码分析(JDK 1.8)

    1.概述 LinkedList 是 Java 集合框架中一个重要的实现,其底层采用的双向链表结构.和 ArrayList 一样,LinkedList 也支持空值和重复值.由于 LinkedList 基 ...

  4. Django笔记十四之统计总数、最新纪录和空值判断等功能

    本篇笔记将介绍一些 Django 查询中统计总数.最新纪录和空值判断等功能. count in_bulk latest.earliest first.last exists contains.icon ...

  5. 电商AARRR模型分析(一)——R语言

    在2010年,互联网创业者增长黑客之父肖恩·埃利斯(Sean Ellis)就创造了增长黑客(Growth hacker)这样一个概念.2015年,范冰撰写的一本新书<增长黑客>确立了Gro ...

  6. 自己动手从零写桌面操作系统GrapeOS系列教程——1.2 GrapeOS真机演示

    学习操作系统原理最好的方法是自己写一个简单的操作系统. GrapeOS操作系统之前一直运行在模拟器和虚拟机中,今天我们来演示一下GrapeOS在真机上运行的情况. 一.物理机真机 今天演示用的真机是一 ...

  7. Golang一日一库之 日志库 zap

    简介 在开发过程中 会使用到日志库去记录错误的日志,尤其是golang中 有无穷无尽的error 如果不记录,当你的代码出错,就无从排错了. zap 是开源的 Go 高性能日志库 主要有以下特点: 支 ...

  8. docker 配置 Mysql主从集群

    docker 配置Mysql集群 Docker version 20.10.17, build 100c701 MySQL Image version: 8.0.32 Docker container ...

  9. 开源后台管理系统解决方案 boot-admin 简介

    介绍 boot-admin 是一款采用前后端分离架构模式的后台管理框架.系统提炼自实际项目,兼具RuoYi-Vue前端分离版和Ruoyi-Cloud微服务版功能与技术特点. boot-admin 既有 ...

  10. [C++基础入门] 7、 指针

    文章目录 7 指针 7.1 指针的基本概念 7.2 指针变量的定义和使用 7.3 指针所占内存空间 7.4 空指针和野指针 7.5 const修饰指针 7.6 指针和数组 7.7 指针和函数 7.8 ...