翻车

【问题描述】

有一天,小武找到了翻车王,给了他n个整数a1,a2,a3,…an,翻车王需要选择其中的k个数,使得选出的k个数中任意两个的差都可以被m整除。

选出的数可以重复,但不可以超过这n个数中该数的个数。

翻车王不想翻车,所以需要你的帮助。

【输入格式】

第一行包括3个整数n,k,m(2 ≤ k ≤ n ≤ 100000,1 ≤ m ≤ 100000),n,k,m意义见题面。

第二行包括n个数a1,a2,a3,…an(0 ≤ ai ≤ 1000000000)。

【输出格式】

如果不可以选出k个数,使得选出这k个数中任意两个的差都可以被m整除,那么输出“No”。

否则,在第一行输出“Yes”。在第二行输出这k个整数b1,b2,...bk(所选的数字),两两数之间有一个空格。

如果有多种选择k个数字的方案,请输出任意一种。

【输入输出样例】

rollover.in rollover.out
4 3 5
2 7 7 7
Yes
2 7 7

【数据说明】

20%的数据n ≤ 15

50%的数据n ≤ 1000

另外20%的数据m ≤ 1000

100%的数据2 ≤ k ≤ n ≤ 10^5,1 ≤ m ≤ 10^5,0≤ ai ≤10^9


题解

暴力--

用一个循环找开头

for(int i=0;i<n;i++){
flag[i]=1;
if(findnext(a+i,1)) return 0;
flag[i]=0;
}

flag[i]是用来标记第i个书有没有用过了的

if(flag[i]==1)
continue;

findnext()返回bool值

用来判断有没有

 #include<bits/stdc++.h>
using namespace std;
int n,k,m;
int a[];
bool flag[];
bool findnext(int now[],int len){
if(len>k) return ;
if(len==k) {
cout<<"Yes"<<endl;
for(int i=;i<len;i++)
cout<<now[i]<<" ";
return ;
}
for(int i=;i<n;i++)//寻找下一个
{
//
// for(int debug=1;debug<=len;debug++) cout<<now[debug]<<" ";
// cout<<endl;
//
if(flag[i]==)
continue;
bool flagnext=;
for(int j=;j<len;j++)
flagnext=flagnext&&(a[i]-now[j])%m==;
if(!flagnext) continue;
//else
int flagn = ;
flag[i]=;
now[len]=a[i];
flagn = findnext(now,len+);
now[len]=;
flag[i]=;
return flagn;
}
return ;
}
int main(){
// freopen("rollover.in","r",stdin);
// freopen("rollover.out","w",stdout);
cin>>n>>k>>m;
for(int i=;i<n;i++)
cin>>a[i];
for(int i=;i<n;i++){
flag[i]=;
if(findnext(a+i,)) return ;
flag[i]=;
}
cout<<"No";
return ;
}

中间的注释(debug)是开始用来调试的。


暴力++

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
const int inf=0X7f7f7f7f;
using namespace std;
int n,k,m,ans=,t=inf;
int main()
{
// freopen("rollover.in","r",stdin);
cin>>n>>k>>m;
long long a[n+],sum[n+];
for(int i=;i<=n;i++)
{
cin>>a[i];
sum[a[i]%m]++;
}
for(int i=;i<m;i++)
{
if(sum[i]>=k)
cout<<"Yes"<<endl;
t=i;
break;
}
if(t==inf)
cout<<"No";
else
for(int i=;i<=n;i++)
{
if(a[i]%m==t);
{
ans++;
if(ans<=k)
cout<<a[i]<<" ";
else break;
}
}
return ;
}

源码来源:https://www.cnblogs.com/YYCether666/p/11185389.html

本来以为会超时的,没想到呀!


std

有关于最小公倍数的数论题

结论:

证明:

设d=gcd(a,b)

a=a'd

b=b'd

所以gcd(a',b')=1,即a',b'互质

题中:a+b是a*b的因子

所以(a'+b')d | a'd*b'd

两边约掉一个d

a'+b' | a'b'd

所以a'+b'<=d

又因为题中:(a'+b')d<=n

所以a'+b'<=sqrt(n)

设k=a'+b'

φ(k)=

等待明天std的下发。。。

嵊州D4T1 翻车 rollover 真的翻车了的更多相关文章

  1. UWP 记一次WTS 和 UCT翻车经历

    这次翻车,真的,在网上绝对找不到回答的. 只有在WTS的Issues讨论中才找到,哈哈 不过这个应该比较少遇到吧,据我所知,提出Issue那个大胸弟和我都遇到了... 翻车具备的条件如下: 1. 使用 ...

  2. 2017CCSP总结——失败(铜)

    这次比赛,算是铩羽而归.尽管是第一次出去打比赛,在经验方面略显不足,但是,归根到底,我这次比赛打的很失败.包括我们学校去的,打的也不好,可以说是全体翻车.真的很对不起带我们去的老师.>_< ...

  3. PKUSC2019划水记

    Day -3~Day -2 划了两天的水,考了两次IOI赛制,垫了两次底.... 怕不是要凉啊(安慰自己才C3还有时间) Day -1 坐火车了,差点把身份证弄丢. 睡了一觉,肝了你的名字(结局草率差 ...

  4. 清北合肥day2-day5

    day2:215这一天的题目相对比较模板化t1:50看错了数据范围求n个点到给出的点哈夫曼距离的最小值我想到的是一种非常zz的做法我们二分答案,然后判断是否在这个距离内有点但是这样前缀和不是很好维护于 ...

  5. Codeforces ECR52 div2翻车记

    A:签到. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> ...

  6. SDOI2019R2翻车记

    额...貌似是学OI以来翻得最惨的一次比赛了呢... 不过还好是初三 但是没有机会和学长们打最后一场告别赛了呢(笑 按照惯例还是要记录一下吧. DAY ? 中考倒计时30天.来写这篇游记. DAY 0 ...

  7. 从谷歌面试翻车到offer收割的心路历程

    首先声明,这只是我的播客随感,其中无法避免有一些个人色彩的见解,请不要在意,我尊敬任何的互联网公司,尊敬研究生期间的老师同学,我只希望给在求学路上的CS同学一些启发. 先介绍一下背景,我是ACM铜牌退 ...

  8. [日常] Codeforces Round #440 Div.2 大力翻车实况

    上次打了一发ABC然后大力翻车...上午考试又停电+Unrated令人非常滑稽...下午终于到了CF比赛... 赛前大力安利了一发然后拉了老白/ $ljm$ / $wcx$ 一起打, 然后搞了个 TI ...

  9. [日常] AtCoder Beginner Contest 075 翻车实录

    别问我为啥要写一篇ABC的游记... 周日打算CF开黑于是就打算先打打ABC找回手速... 进场秒掉 $A$ 和 $B$ , 小暴力一脸偷税 然后开 $C$ ...woc求桥? 怎么办啊我好像突然忘了 ...

随机推荐

  1. C#热敏打印图片 串口打印图片

    原文:C#热敏打印图片 串口打印图片 如图,一步一步慢慢调出来的 //串口通信类 public System.IO.Ports.SerialPort serialPort = null; serial ...

  2. Genymotion常见问题解决方案

    最近更新了Genymotion之后, 出了一大堆问题, 花了差不多两天的时间, 把一系列问题基本遇到遍了, 终于修成正果, 分享出来希望可以让大家少走一点弯路. 无法启动Genymotion;关键字: ...

  3. php将两个数组相同的key合并到一个数组

    $arr = array(     array(     'id' => 1,     'user_name'=>'test1'     ),     array(     'id' =& ...

  4. 在2005年,Unicode 的第十万个字符被采纳且认可成为标准之一(超过这65535范围的Unicode字符,则需要使用一些诡异的技巧来实现)

    在计算机科学领域中,Unicode(统一码.万国码.单一码.标准万国码)是业界的一种标准,它可以使电脑得以体现世界上数十种文字的系统.Unicode 是基于通用字符集(Universal Charac ...

  5. 对OO的封装了有了新的理解——希望是普通函数来写总体流程来统管类似的业务,但却又涉及具体操作的函数,仍然可以达到目的

    就是不厌其烦,把那个具体操作函数封装成虚函数,只需要返回它的结果就行.而总体流程根据这个结果继续进行处理,这样就能总体流程和虚函数两不误了.

  6. asp.net core2.0中网站发布的时候,视图文件不被打包成dll

    项目csproj文件里面加 <Project Sdk="Microsoft.NET.Sdk.Web"> <PropertyGroup> <Target ...

  7. LCID

    Language Location (or type) Language ID Language tag Supported version Afar   0x1000 aa Release 9 Af ...

  8. UBUNTU 16.04 + CUDA8.0 + CUDNN6.0 + OPENCV3.2 + MKL +CAFFE + tensorflow

    首先说一下自己机子的配置 CPU:Intel(R) Core(TM) i5-5600 CUP @3.20GHz *4 GPU : GTX 1060 OS : 64bit Ubuntu16.04LTS ...

  9. Linux可以把vmdk当做磁盘加载进去

    VMware虚拟机由于停电,无法启动MAC系统 下午的时候,正在开发ios app,结果停电了.当时还不知道,伴随而来的灾难竟然折腾了好几天,真是心力交瘁. 我是在VMware虚拟机下装的Mac os ...

  10. Qt自定义委托在QTableView中绘制控件、图片、文字(内容比较全)

    自定义委托,继承于,QStyledItemDelegate类,重载Paint()函数, 1.实现在QTableView中绘制 格式字符串 2.实现在QTableView中绘制进度条 3.实现在QTab ...