Codeforces印象

这两天抽时间去codeforces体验了一把。

首先,果然有众多大牛存在。非常多名人一直參加每周一次的比赛。积分2000+,并參与出题。

另外。上面题目非常多。预计至少一千题。

比赛结束后,题目将转为练习题,能够持续尝试。每道题目都有标签,如greedy。 math, matrices等等,能够点击对应的标签仅仅做相关的题目。可惜我做了好几道之后才发现。

这次解决的题目

首次尝试。这次做的几个都是选的完毕人数最多的,比較简单,但还是有些东西是从中新学习到的。以后最好分类练习。

1A Theatre Square

  • 用a x a的砖块去铺满面积m x n的广场,不准破坏砖块,同意超出广场,求砖块数目
  • 分别计算长宽至少多少块就可以
  • 小技巧:(m-1)/a+1来计算长度方向的砖块数目
#include<iostream>
#include<limits>
using namespace std; int main(){
long long m,n,a;
//cout << numeric_limits<long>::max() << endl;
cin >> m >> n >> a;
cout << ((m-1)/a + 1)*((n-1)/a + 1) << endl;
return 0;
}

4A Watermelon

  • 太过简单

158A Next Round

  • 太过简单

71A Way Too Long Words

  • 给定一个单词,假设长度超过10,改成缩写形式:首字母+中间的字母个数+尾字母
  • 直接输出结果就可以

118A String Task

  • 给定一个单词,删掉全部元音字母,其余字母转换为小写并每一个字母前加.符号
  • 使用ostringstream和tolower函数
#include<iostream>
#include<sstream>
using namespace std;
int main(){
string str;
cin >> str;
ostringstream ostr;
for(auto i:str){
char t=tolower(i);
if(t == 'a' || t=='o' || t=='y'||t=='e' ||t=='u' || t=='i')
;
else
ostr<< '.' << t;
}
cout << ostr.str() << endl;
return 0;
}

158B Taxi

  • n个小组。每组不超过4人,出租车每车不能超过4人。同组人不能分开,求最少要多少辆车
  • 贪心。尽量坐满每一辆车,剩下的进行组合
#include<iostream>
#include<vector>
using namespace std; int main(){
int n;
cin >> n;
// can't initialize a vector with its element;
//vector<int> test(1,2,3,4);
vector<int> stat(4,0);
for(int i = 0;i < n;i++){
int tmp;
cin >> tmp;
stat[tmp-1] += 1;
} int num_taxi = 0;
num_taxi += stat[3];
if(stat[2]>= stat[0]){
num_taxi += stat[2];
num_taxi += (stat[1]+1)/2;
}
else{
num_taxi += stat[2];
stat[0] -= stat[2];
num_taxi += (stat[0] + stat[1]*2 -1)/4 + 1;
} cout << num_taxi << endl;
return 0;
}

50A Domino piling

  • mxn的广场用2x1的砖块铺满。至少多少块?
  • 分析m,n在为奇偶的情况下的铺法就可以

231A Team

  • 太过简单

116A Tram

  • 太多简单

131A cAPS lOCK

  • 依据特定条件更改字符串中的字母大写和小写
  • 关键是怎样遍历字符串中的字符并更改大写和小写
  • for(char &c:s) 能够方便的遍历字符串
  • cctype头文件里包括了islower,tolower,isupper,toupper等char字符处理函数
#include<iostream>
#include<cctype>
using namespace std; bool meet_rule(string s)
{
for(char &c:s.substr(1))
{
if(islower(c))
return false;
}
return true;
} int main()
{
string s;
cin >> s;
if(meet_rule(s))
{
for(char &c:s)
{
if(true )
{
if(islower(c))
c = toupper(c);
else
c = tolower(c);
}
}
}
cout << s << endl;
return 0;
}

282A Bit++

  • 太过简单

转载请注明作者:Focustc,博客地址为http://blog.csdn.net/caozhk,原文链接为点我

Codeforces初体验的更多相关文章

  1. .NET平台开源项目速览(15)文档数据库RavenDB-介绍与初体验

    不知不觉,“.NET平台开源项目速览“系列文章已经15篇了,每一篇都非常受欢迎,可能技术水平不高,但足够入门了.虽然工作很忙,但还是会抽空把自己知道的,已经平时遇到的好的开源项目分享出来.今天就给大家 ...

  2. Xamarin+Prism开发详解四:简单Mac OS 虚拟机安装方法与Visual Studio for Mac 初体验

    Mac OS 虚拟机安装方法 最近把自己的电脑升级了一下SSD固态硬盘,总算是有容量安装Mac 虚拟机了!经过心碎的安装探索,尝试了国内外的各种安装方法,最后在youtube上找到了一个好方法. 简单 ...

  3. Spring之初体验

                                     Spring之初体验 Spring是一个轻量级的Java Web开发框架,以IoC(Inverse of Control 控制反转)和 ...

  4. Xamarin.iOS开发初体验

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKwAAAA+CAIAAAA5/WfHAAAJrklEQVR4nO2c/VdTRxrH+wfdU84pW0

  5. 【腾讯Bugly干货分享】基于 Webpack & Vue & Vue-Router 的 SPA 初体验

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57d13a57132ff21c38110186 导语 最近这几年的前端圈子,由于 ...

  6. 【Knockout.js 学习体验之旅】(1)ko初体验

    前言 什么,你现在还在看knockout.js?这货都已经落后主流一千年了!赶紧去学Angular.React啊,再不赶紧的话,他们也要变out了哦.身旁的90后小伙伴,嘴里还塞着山东的狗不理大蒜包, ...

  7. 在同一个硬盘上安装多个 Linux 发行版及 Fedora 21 、Fedora 22 初体验

    在同一个硬盘上安装多个 Linux 发行版 以前对多个 Linux 发行版的折腾主要是在虚拟机上完成.我的桌面电脑性能比较强大,玩玩虚拟机没啥问题,但是笔记本电脑就不行了.要在我的笔记本电脑上折腾多个 ...

  8. 百度EChart3初体验

    由于项目需要在首页搞一个订单数量的走势图,经过多方查找,体验,感觉ECharts不错,封装的很细,我们只需要看自己需要那种类型的图表,搞定好自己的json数据就OK.至于说如何体现出来,官网的教程很详 ...

  9. Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验

    Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出E ...

随机推荐

  1. js时间格式化工具,时间戳格式化,字符串转时间戳

    在开发中经常会用到时间格式化,有时候在网上搜索一大堆但不是自己想要的,自己总结一下,写一个时间格式化工具方便以后直接使用,欢迎大家来吐槽…… 1 2 3 4 5 6 7 8 9 10 11 12 13 ...

  2. 面向对象编程(四)继承,概念及super关键字,final关键字,Object类常见方法

    继承 概念: ①   继承背后的思想就是基于已存在的类来构建新类; ②   当从已存在类继承时,就重用了它的方法和属性,还可以添加新的方法和属性来定制新类以应对需求; ③   当从其它类导出的类叫作子 ...

  3. Spring @注解详解(转)

    1.@controller 控制器(注入服务) 2.@service 服务(注入dao) 3.@repository dao(实现dao访问) 4.@component (把普通pojo实例化到spr ...

  4. formData使用总结

    1.formData基本使用 //可以从form元素初始化一个FormData对象,或者new一个空对象 var formData = new FormData([fromElement]); //可 ...

  5. Nginx配置https双向认证

    1.      前期的准备工作: 安装openssl和nginx的https模块 cd ~/ mkdir ssl cd ssl mkdir demoCA cd demoCA mkdir newcert ...

  6. 标准C程序设计七---44

    Linux应用             编程深入            语言编程 标准C程序设计七---经典C11程序设计    以下内容为阅读:    <标准C程序设计>(第7版) 作者 ...

  7. mysql into outfile 导出

    <sql> into outfile 'xxx.txt' FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n'; <sql> 表示 ...

  8. AC日记——货车运输 codevs

    3287 货车运输 2013年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Descri ...

  9. Python基础数据类型补充及深浅拷贝

    本节主要内容:1. 基础数据类型补充2. set集合3. 深浅拷贝主要内容:一. 基础数据类型补充首先关于int和str在之前的学习中已经讲了80%以上了. 所以剩下的自己看一看就可以了.我们补充给一 ...

  10. 从壹开始 [ Ids4实战 ] 之三║ 详解授权持久化 & 用户数据迁移

    回顾 哈喽大家周三好,今天终于又重新开启 IdentityServer4 的落地教程了,不多说,既然开始了,就要努力做好