AtCoder Regular Contest 099

C - Minimization

题意

题意:给出一个n的排列。每次操作可以使一段长度为K的连续子序列变成该序列的最小数。求最少几次使得整个数列全部为1。

分析

可以发现每次操作都要包含1。所以我们的答案就应该是 \(\frac{n-k}{k-1}\)。

直接\(O(1)\)求就可以了。

#include <iostream>
#include <cstdlib>
#include <cmath>
#include <string>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <queue>
#include <set>
#include <map>
#define re register
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
#define MAXN 4000007
#define ll long long
#define mo 19930726
#define ls rt<<1
#define rs rt<<1|1
using namespace std;
typedef unsigned long long ull;
int n,k;
int main()
{
cin>>n>>k;
int ans=1;
n-=k;
ans+=n/(k-1);
n%=(k-1);
if(n) ans+=1;
cout<<ans;
}

D - Snuke Numbers

题意

令S(n)表示n这个数各位之和。定义一个数n合法:所有m>n,都有n/S(n)<=m/S(m)。

输出前K个合法的数。

分析

发现所有的snuke数的尾数基本都是9。

所以我们直接暴力求就可以了。

#include <iostream>
#include <cstdlib>
#include <cmath>
#include <string>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <queue>
#include <set>
#include <map>
#define re register
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
#define MAXN 4000007
#define ll long long
#define mo 19930726
using namespace std;
typedef unsigned long long ull;
#define ms(arr) memset(arr, 0, sizeof(arr))
const int inf = 0x3f3f3f3f;
int n;
ll clac(ll x)
{
ll cnt=0;
while(x) cnt+=x%10,x/=10;
return cnt;
}
int main()
{
ll x=0,x1,x2,m=1;
cin>>n;
for(int i=1;i<=n;i++){
x1=x+m;x2=x+m*10;
if(x1*clac(x2)<=x2*clac(x1))
x=x1;
else x=x2,m*=10;
printf("%lld\n",x);
}
}

E - Independence

题意

题意:给出一个无向图,让你将它分成两部分使得,每部分的点互相有边相连。

最小化边的数量。

分析

建立补图。

对补图进行二分图染色。

可以发现如果补图不是二分图的话,不合法。

然后对于每个联通块的两种颜色x和y,我们要通过交换一些x和y使\(\sum^n_{i=1}x[i]\)尽量接近于\(\frac N 2\)。

背包求一下就可以了。

#include <iostream>
#include <cstdlib>
#include <cmath>
#include <string>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <queue>
#include <set>
#include <map>
#define re register
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
#define MAXN 4000007
#define mo 19930726
using namespace std;
typedef unsigned long long ull;
#define ms(arr) memset(arr, 0, sizeof(arr))
const int inf = 0x3f3f3f3f;
int f[1001][1001],x[100001],y[10001],col[10001];
int n,m,a[1001][1001],cnt[100001],tot;
bool vis[100001];
struct po
{
int nxt,to;
};
po edge[1000001];
inline int read()
{
int x=0,c=1;
char ch=' ';
while((ch>'9'||ch<'0')&&ch!='-')ch=getchar();
while(ch=='-') c*=-1,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-'0',ch=getchar();
return x*c;
}
inline void put_color(int u)
{
vis[u]=1;
cnt[col[u]]++;
for(re int i=1;i<=n;i++){
if(a[u][i]==0){
if(!vis[i]){
col[i]=!col[u];
put_color(i);
} else if(col[u]==col[i]){
cout<<-1;
exit(0);
}
}
}
}
int main()
{
n=read();m=read();
for(re int i=1;i<=n;i++) a[i][i]=1;
for(re int i=1;i<=m;i++){
int u=read(),v=read();
a[u][v]=a[v][u]=1;
}
for(re int i=1;i<=n;i++) {
if(!vis[i]){
cnt[0]=cnt[1]=0;
put_color(i);
tot++;
x[tot]=cnt[0];
y[tot]=cnt[1];
}
}
f[0][0]=1;
for(re int i=1;i<=tot;i++){
for(re int j=0;j<=n;j++){
if(f[i-1][j]){
f[i][j+x[i]]=1;
f[i][j+y[i]]=1;
}
}
}
int ans=n*n;
for(re int i=0;i<=n;i++){
if(f[tot][i]) ans=min(ans,i*(i-1)/2+(n-i)*(n-i-1)/2);
}
cout<<ans; }

AtCoder Regular Contest 099的更多相关文章

  1. AtCoder Regular Contest 099 (ARC099) E - Independence 二分图

    原文链接https://www.cnblogs.com/zhouzhendong/p/9224878.html 题目传送门 - ARC099 E - Independence 题意 给定一个有 $n$ ...

  2. AtCoder Regular Contest 099 C~E

    C - Minimization 枚举就可以了 因为最后一定会变成1,所以第一次操作的区间就包含1会比较优,然后枚举1在第一次操作区间里排第几个取min即可 #include<iostream& ...

  3. AtCoder Regular Contest 061

    AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...

  4. AtCoder Regular Contest 094 (ARC094) CDE题解

    原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...

  5. AtCoder Regular Contest 092

    AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...

  6. AtCoder Regular Contest 093

    AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...

  7. AtCoder Regular Contest 094

    AtCoder Regular Contest 094 C - Same Integers 题意: 给定\(a,b,c\)三个数,可以进行两个操作:1.把一个数+2:2.把任意两个数+1.求最少需要几 ...

  8. AtCoder Regular Contest 095

    AtCoder Regular Contest 095 C - Many Medians 题意: 给出n个数,求出去掉第i个数之后所有数的中位数,保证n是偶数. \(n\le 200000\) 分析: ...

  9. AtCoder Regular Contest 102

    AtCoder Regular Contest 102 C - Triangular Relationship 题意: 给出n,k求有多少个不大于n的三元组,使其中两两数字的和都是k的倍数,数字可以重 ...

随机推荐

  1. uiautomatorviewer.bat使用方法

    在android目录下找到uiautomatorviewer.bat,然后双击,页面的第二个按钮连接设备 D:\Program Files\android-sdk-windows\tools\uiau ...

  2. Spinner --- 功能和用法

    第一种方法: 使用Spinner时需要配置选项的资源文件,资源文件为一个string类型的数组 在res下的values文件夹下新建一个xml文件 内容为: <?xml version=&quo ...

  3. 【NOI2015】品酒大会[后缀数组]

    #131. [NOI2015]品酒大会 统计 描述 提交 自定义测试 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品酒家”和“首席猎手”两个奖项, ...

  4. 《从零开始学Swift》学习笔记(Day 57)——Swift编码规范之注释规范:文件注释、文档注释、代码注释、使用地标注释

    原创文章,欢迎转载.转载请注明:关东升的博客 前面说到Swift注释的语法有两种:单行注释(//)和多行注释(/*...*/).这里来介绍一下他们的使用规范. 1.文件注释 文件注释就在每一个文件开头 ...

  5. [LintCode] 合并排序数组

    A subroutine of merge sort. class Solution { public: /** * @param A and B: sorted integer array A an ...

  6. js写css()方法,记得加引号“ ”,除非是数字

    js写css()方法,记得加引号“ ”,除非是数字.如: $("#android").css({ "position": "absolute" ...

  7. Handlebars.js,Json+ajax+拼html

    英文版:http://handlebarsjs.com./ 原文链接:http://www.cnblogs.com/diligenceday/p/4105229.html, http://segmen ...

  8. 通过手机浏览器打开APP或者跳转到下载页面.md

    目录 通过手机浏览器打开APP或者跳转到下载页面 添加 schemes 网页设置 参考链接 通过手机浏览器打开APP或者跳转到下载页面 以下仅展示最简单的例子及关键代码 由于硬件条件有限,仅测试了 A ...

  9. kafka 自启脚本

    每次使用的时候都要手动去启动真头痛! 解决办法,自启吧! 方法一: 方法一: /etc/rc.local中添加 文件地址记得替换掉 ,我没使用这种,发现不是每次都行,就换了第二种方法 /usr/loc ...

  10. Linux基础命令(三)

    作业一:1) 将用户信息数据库文件和组信息数据库文件纵向合并为一个文件/1.txt(覆盖) cat /etc/passwd /etc/group >/1.txt 2) 将用户信息数据库文件和用户 ...