849A - Odds and Ends

问能否将序列划分为奇数个长度奇数的奇数开头奇数结尾的子区间。

一开始想dp。。不过没必要。

const int N=201000;
int n,a[N];
int main() {
sf(n);
rep(i,1,n+1)sf(a[i]);
bool ans=1;
if(a[1]%2==0||a[n]%2==0||n%2==0){
ans=0;
}
puts(ans?"Yes":"No");
return 0;
}

849B - Tell Your World

n个点坐标为\((i,y_i)\),问是否有两条不重合的平行线,点都在上面,且一条线至少一个点。

找到和第1,2个点不共线的点b,然后枚举这三条边作为平行线的一条,其它点就必须在线上或者和另一个点连线和这条线平行。

我sb了把b点和第3个点swap了一下(哭)。代码写得有点长。。

const int N=201000;
int n,y[N];
double k;
int main() {
sf(n);
rep(i,0,n)sf(y[i]);
int b=-1;
rep(i,2,n)if((ll)(y[i]-y[0])*(i-1)!=(ll)(y[i]-y[1])*i){
b=i;break;
}
if(~b){
bool ans=0,tans=1;
rep(i,2,n)if(i!=b){
bool t=(ll)(y[i]-y[0])*(i-1)!=(ll)(y[i]-y[1])*i;
bool s=(ll)(y[i]-y[b])!=(ll)(y[1]-y[0])*(i-b);
if(s && t){
tans=0;break;
}
}
ans|=tans;
tans=1;
rep(i,2,n)if(i!=b){
bool t=(ll)(y[i]-y[0])*(i-b)!=(ll)(y[i]-y[b])*i;
bool s=(ll)(y[i]-y[1])*b!=(ll)(y[b]-y[0])*(i-1);
if(s && t){
tans=0;break;
}
}
ans|=tans;
tans=1;
rep(i,2,n)if(i!=b){
bool t=(ll)(y[i]-y[1])*(i-b)!=(ll)(y[i]-y[b])*(i-1);
bool s=(ll)(y[i]-y[0])*(b-1)!=(ll)(y[b]-y[1])*i;
if(s && t){
tans=0;break;
}
}
ans|=tans;
puts(ans?"Yes":"No");
}else {
puts("No");
}
return 0;
}

849C - From Y to Y

给你一个k,求一个字符串,要求组成的费用为k。

费用:两个字符串拼起来,代价为每个字母在两个串中的个数之积求和,一开始是n个字母,拼n-1次可以成为一个长度n的字符串。

不同字母的计算是独立的,相同的两个字母在两个不同串里乘起来时贡献了1,所以有\(num_i\)个i字母就有\(C(num_i,2)\)次贡献。

k最大100000,每次贪心找贡献不超过k的最大的num,5个字母都足够了。

我漏了0的情况又wa一次→_→

const int N=1000;
int pre[N];
int n;
char s[N*N];
int len;
int main() {
rep(i,0,N)pre[i]=(i-1)*i/2;
sf(n);
if(n==0)puts("a");
int j,c;
while(n>0){
j=lower_bound(pre, pre+N, n)-pre;
if(pre[j]>n)--j;
n-=pre[j];
rep(i,0,j)s[len++]='a'+c;
++c;
}
printf("%s",s);
return 0;
}

【cf849ABC】的更多相关文章

  1. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  2. 【原】谈谈对Objective-C中代理模式的误解

    [原]谈谈对Objective-C中代理模式的误解 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这篇文章主要是对代理模式和委托模式进行了对比,个人认为Objective ...

  3. 【原】FMDB源码阅读(三)

    [原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...

  4. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  5. 【调侃】IOC前世今生

    前些天,参与了公司内部小组的一次技术交流,主要是针对<IOC与AOP>,本着学而时习之的态度及积极分享的精神,我就结合一个小故事来初浅地剖析一下我眼中的“IOC前世今生”,以方便初学者能更 ...

  6. Python高手之路【三】python基础之函数

    基本数据类型补充: set 是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object ...

  7. Python高手之路【一】初识python

    Python简介 1:Python的创始人 Python (英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/), 是一种解释型.面向对象.动态数据类型的高级程序设计语言,由荷兰人Guido ...

  8. 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】

    说17号发超简单的教程就17号,qq核审通过后就封装了这个,现在放出来~~ 这个是我封装的一个开源项目:https://github.com/dunitian/LoTQQLogin ————————— ...

  9. 【原】FMDB源码阅读(二)

    [原]FMDB源码阅读(二) 本文转载请注明出处 -- polobymulberry-博客园 1. 前言 上一篇只是简单地过了一下FMDB一个简单例子的基本流程,并没有涉及到FMDB的所有方方面面,比 ...

随机推荐

  1. c++入门之结构体初步

    结构体实际上是一种数据结构的雏形,对结构体的灵活使用很多时候可以带来很多便利.下面给出一个关于结构体的程序: #include "iostream" # include " ...

  2. Selenium库

    '''自动化测试工具,支持多种浏览器.爬虫中主要用来解决JavaScrip渲染的问题.''''''基本使用'''from selenium import webdriverfrom selenium. ...

  3. H5上传图片之canvas

    H5上传图片之canvas,使用canvas处理压缩图片再上传 html代码: <form action="" method="post"> < ...

  4. ubuntu中更改apache默认目录的方法

    如上,在这两个文件中,我都改为/home/www 及/home/www/html

  5. Thrift序列化与反序列化

    Thrift序列化与反序列化的实现机制分析 Thrift是如何实现序死化与反序列化的,在IDL文件中,更改IDL文件中的变量序号或者[使用默认序号的情况下,新增变量时,将新增的变量不放在IDL文件的结 ...

  6. Java参数是值传递还是引用传递?

    先来看看参数是如何传递的. 一.参数的传递 1.基本类型的参数传递 public static void main(String[] args) { int a = 1; fun(a); } priv ...

  7. Python之发邮件

    使用模块yagmail(使用收藏的yagmail,现在的第三方模块不能解决中文乱码问题) import yagmail user='xxx@126.com' password='xxxxxx' #使用 ...

  8. 学习docker——命令总结

    安装docker的方法可以参考:Ubuntu.CentOS.Windows.MacOS 查看版本信息 → ~ $ docker --version Docker version 18.03.1-ce, ...

  9. 解决ERR Client sent AUTH, but no password is set

    在搭建cookies池时,需要将账号密码保存到redis,保存时报错:ERR Client sent AUTH, but no password is set 报错原因:Redis服务器没有设置密码, ...

  10. 理解git工作区和暂存区

    版本库 在工作区目录中有一个.git文件,这个其实不是工作区而是Git的版本库 版本库中包含两个部分,一个是暂存区index/stage,另一个是git自动为我们创建的第一个分支master,以及一个 ...