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. Sogou日志分析(hive)

    1. 数据准备 1.1 数据预先放在mac本地桌面的“VB共享文件夹”中,从VisualBox虚拟机中/mnt/VBShare共享目录中转移到resources目标目录. [cloudera@quic ...

  2. Jeddict:从服务器的验证过程,思考学习新事物的套路

    结合一路研究Jeddict使用的过程经验来看,在这里说一下关于服务器配置的东西.在我们团队,最开始用这个插件的时候,因为公司用的应用服务器是Jboss EAP 7,所以,我们自然而然的,想当然的直接使 ...

  3. [转]Visual Studio调试之符号文件

    http://www.cnblogs.com/killmyday/archive/2009/10/14/1582882.html 前面在不能设置断点的检查步骤和Visual Studio调试之断点进阶 ...

  4. 【bzoj3939】[Usaco2015 Feb]Cow Hopscotch 动态开点线段树优化dp

    题目描述 Just like humans enjoy playing the game of Hopscotch, Farmer John's cows have invented a varian ...

  5. ajax对象的获取及其常用属性

    ajax对象的获取及其常用属性 (1)什么是ajax asynchronous javascript and xml(异步的javascript和xml). 是一种用来改善用户体验的技术,其实质是利用 ...

  6. [SPOJ-PT07J] Query on tree III (主席树)

    题意翻译 你被给定一棵带点权的n个点的有根数,点从1到n编号. 定义查询 query(x,k): 寻找以x为根的k大点的编号(从小到大排序第k个点) 假设没有两个相同的点权. 输入格式: 第一行为整数 ...

  7. java面试题之有哪几种方式可以让线程阻塞

    线程阻塞方式: 1.join 2.sleep 3.yield 4.改变线程的优先级 5.将线程设置成守护线程(jvm中的垃圾回收线程) 参考:https://blog.csdn.net/liyucho ...

  8. The reference to entity "characterEncoding" must end with the ';' delimiter (Mybatis + Mysql)

    数据源配置时加上编码转换格式后出问题了: The reference to entity "characterEncoding" must end with the ';' del ...

  9. 【NOIP2016练习&BZOJ2125】T3 sp (树上倍增,最短路)

    题意:给一个N个点M条边的连通无向图,满足每条边最多属于一个环,有Q组询问,每次询问两点之间的最短路径. 对于80%的数据环的个数<=1 对于100%的数据N<=10000,Q<=1 ...

  10. canvas之webgl的打开方式

    OK,一个完整的dome是从无到有的.这篇文章将记录我的webgl之旅.不定时更新. 首先,新建一个canvas元素. 然后获取到它. var e = document.ElementById('ca ...