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. java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()解决办法

    代码改变世界 java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.pre ...

  2. HashSet源码分析 jdk1.6

    Set的特点:Set元素无顺序,且元素不可以重复. 1.定义 public class HashSet<E> extends AbstractSet<E> implements ...

  3. HDU——2609How many(字符串的最小表示法+substr)

    How many Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  4. mysql 游标的使用总结

    一.游标的基本概念 游标:游标是一个存储在Mysql服务器上的数据库查询,它不是一条select语句,而是被该语句检索出来的结果集. 本人,学习游标中,曾遇到一个问题,循环总是最后多执行一次.下面分析 ...

  5. python 面向对象与类的基本知识

    一  什么是面向对象,面向对象与类的关系. 面向对象的程序设计是用来解决扩展性. 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象 ...

  6. “百度杯”CTF比赛 十月场_Login

    题目在i春秋ctf大本营 打开页面是两个登录框,首先判断是不是注入 尝试了各种语句后,发现登录界面似乎并不存在注入 查看网页源代码,给出了一个账号 用帐密登陆后,跳转到到member.php网页,网页 ...

  7. HDU 6206 Apple

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6206 判断给定一点是否在三角形外接圆内. 给定三角形三个顶点的坐标,如何求三角形的外心的坐标呢? 知乎 ...

  8. 详解webpack-dev-server的配置属性

    1.devServer.contentBase   它指定了服务器资源的根目录,如果不写入contentBase的值,那么contentBase默认是项目的目录. 在上面例子中产生错误和后来解决错误的 ...

  9. WEB接口测试之Jmeter接口测试自动化 (三)(数据驱动测试)

     接口测试与数据驱动 1简介 数据驱动测试,即是分离测试逻辑与测试数据,通过如excel表格的形式来保存测试数据,用测试脚本读取并执行测试的过程. 2 数据驱动与jmeter接口测试 我们已经简单介绍 ...

  10. Network | parity bit

    奇偶校验位是一个表示给定位数的二进制数中1的个数是奇数还是偶数的二进制数.奇偶校验位是最简单的错误检测码. A parity bit, or check bit is a bit added to t ...