[刷题]算法竞赛入门经典 3-1/UVa1585 3-2/UVa1586 3-3/UVa1225
书上具体所有题目:http://pan.baidu.com/s/1hssH0KO(我也是在网上找到的pdf,但不记得是从哪里搜刮到的了,就重新上传了一遍)
PS:第一次写博客分享我的代码,不知道我对csdn的使用姿势对不对。想不出来要说些什么哈o(^▽^)o,那就直接开工,先写一篇试试。
题目:算法竞赛入门经典 3-1/UVa1585:Score
代码:
#include<iostream>
#define MAX 83 int main()
{
int num;
std::cin >> num;
while (num--) {
char str[MAX], *ch = str;
int score = 0, sum = 0;
std::cin >> str;
while (*ch != '\0')
sum += (*(ch++) == 'X' ? score = 0 : ++score);
std::cout << sum << '\n';
}
return 0;
}
分析:MAX定为83而不是题目限制的80是为了传说中的鲁棒性,其他好像没什么好说的。。。下一题。。
题目:算法竞赛入门经典 3-2/UVa1586:Molar Mass
代码:
#include<iostream>
#include<iomanip> inline float f(char c)//得到分子量
{
switch (c) {
case 'C':return 12.01;
case 'H':return 1.008;
case 'O':return 16.00;
case 'N':return 14.01;
default:std::cerr << "error!\n";
}
std::cout << '\'' << c << '\'';
exit(0);
}
inline bool g(char c)//判断char的内容是不是数字
{
if (c >= '0'&&c <= '9') return 1;return 0;
} int main()
{
int num;//判断输入个数
std::cin >> num;
std::cout << std::fixed << std::setprecision(3);
while (num--) {
float sum = 0;
char str[83], *ch = str;
std::cin>>str;
while (*ch != '\0') {//此情况下不是'\0'就是字母
int n = 0;
char c = *ch;
while (g(*++ch))//是数字
n = n * 10 + *ch - '0';
if (!n) n = 1;
sum += f(c)*n;//若不是字母则报错结束程序
}
std::cout << sum << '\n';
}
return 0;
}
分析:这次写了注释,好像也没什么好说的了。。不过对于inline,我知道编译器如果觉得这个函数不够小巧,会忽略inline,但我一直不知道要多小才能编译器不忽略inline。然后因为程序比较小,所以没有给两个函数取名字,直接叫f和g。
题目:算法竞赛入门经典 3-3/UVa1225:Digit Counting
代码:
#include<iostream>
#include<cmath> int main()
{
int num;
std::cin >> num;
while (num--) {
int n, n2,d=1, times[10] = { 0 };//n:输入的数字,n2:备份n,times:保存各数字出现的次数
do std::cin >> n;while (n >= 10000);
n2 = n;
while (n2 /= 10) ++d;//d为位数
n2 = n;
int t = 1, sum = 0;//t不断乘以10,sum代表所有数字一样多的部分
while (d--) {//f代表某一位
int f = n2 % 10;
n2 /= 10;
sum += n2*t;
times[0] += (n2 - 1)*t;//0太奇葩,总比别人少一个,单独算
for (int i = 0;i < f;++i) times[i] += t;
times[f] += 1 + n%t;//当前位最大数字分开算
t *= 10;
}
std::cout << times[0];
for (int i = 1;i < 10;++i)
std::cout << ' ' << (times[i] += sum);
std::cout << '\n';
}
return 0;
}
分析:这题我看过网上其他人的做法,他们竟然真的把这个长长的数字串写进了字符数组,然后再遍历数组数一遍。总感觉这字符数组长度得爆炸而且慢。
这题的规律是:(划横线的是具体的那个数字)(以123为例)
第一列也就是12*1的那列,代表(除了零)所有数共有的部分(就比如123的前100中每个数字出现的一样多),在代码里用sum表示,比如对于十位上的每个数字,都出现了123/(10^2)*10次
第二列 也就是XXX各+1那列,代表特殊的那几个地方,就比如十位上数字是2,那么那超过100的23(准确说是20,个位上3不算在里面的原因在最后一列)就在此计算,但此计算不包括2
而最后一列又是最特殊的,比如十位上的2的与别人不同的地方在此计算,十位2开头的数120、121、122、123,十位上的2出现(123%10+1)=4次
零我是分开单独算的,因为它比较奇葩,就比如1、2、3而不是01、02、03,十位上的0是不写的,其实规律一样的。
嗯、工科男表达能力太差了。。感觉我越说越复杂。。。果然多写写博客练练表达是有好处的。
这次就上传这几题,看题目难度和代码长度来判断每次上传多少题目。
[刷题]算法竞赛入门经典 3-1/UVa1585 3-2/UVa1586 3-3/UVa1225的更多相关文章
- [刷题]算法竞赛入门经典 3-12/UVa11809
		书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 题目:算法竞赛入门经典 3-4/UVa11809:Floating-Point Numbers 代码: //UVa11 ... 
- [刷题]算法竞赛入门经典 3-10/UVa1587 3-11/UVa1588
		书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 题目:算法竞赛入门经典 3-10/UVa1587:Box 代码: //UVa1587 - Box #include&l ... 
- [刷题]算法竞赛入门经典 3-7/UVa1368 3-8/UVa202 3-9/UVa10340
		书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 都是<算法竞赛入门经典(第二版)>的题目,标题上没写(第二版) 题目:算法竞赛入门经典 3-7/UVa13 ... 
- [刷题]算法竞赛入门经典 3-4/UVa455 3-5/UVa227 3-6/UVa232
		书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 题目:算法竞赛入门经典 3-4/UVa455:Periodic Strings 代码: //UVa455 #inclu ... 
- [刷题]算法竞赛入门经典(第2版) 4-6/UVa508 - Morse Mismatches
		书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,10 ms) //UVa508 - Morse Mismatches #include< ... 
- [刷题]算法竞赛入门经典(第2版) 5-15/UVa12333 - Revenge of Fibonacci
		题意:在前100000个Fibonacci(以下简称F)数字里,能否在这100000个F里找出以某些数字作为开头的F.要求找出下标最小的.没找到输出-1. 代码:(Accepted,0.250s) / ... 
- [刷题]算法竞赛入门经典(第2版) 5-13/UVa822 - Queue and A
		题意:模拟客服MM,一共有N种话题,每个客服MM支持处理其中的i个(i < N),处理的话题还有优先级.为了简化流程方便出题,设每个话题都是每隔m分钟来咨询一次.现知道每个话题前来咨询的时间.间 ... 
- [刷题]算法竞赛入门经典(第2版) 4-5/UVa1590 - IP Networks
		书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,0 ms) //UVa1590 - IP Networks #include<iost ... 
- [刷题]算法竞赛入门经典(第2版) 6-7/UVa804 - Petri Net Simulation
		题意:模拟Petri网的执行.虽然没听说过Petri网,但是题目描述的很清晰. 代码:(Accepted,0.210s) //UVa804 - Petri Net Simulation //Accep ... 
随机推荐
- parentNode和parentElement区别
			parentNode跟parentElement除了前者是w3c标准,后者只ie支持 当父节点的nodeType不是1,即不是element节点的话,它的parentElement就会是null 一般 ... 
- servlet与jsp的区别(转)
			一.基本概念 1.1 Servlet Servlet是一种服务器端的Java应用程序,具有独立于平台和协议的特性,可以生成动态的Web页面.它担当客户请求(Web浏览器或其他HTTP客户程序)与服务器 ... 
- Linux之第一个shell命令
			今天在学习shell脚本的编写,网上看了一个helloworld的栗子: #!/bin/sh #print hello world in the console window a = "he ... 
- 老李分享:webservice是什么?2
			web service 组件 基本的 web service 平台是 XML + HTTP.所有标准的 web service 使用以下组件: SOAP(简单对象访问协议) UDDI(通用描述.发现与 ... 
- Hybris license过期的解决办法
			license过期编译是可以通过的,但是启动服务会报错: LICENSE VERIFICATION HAS FAILED! Your demo/develop license has expired, ... 
- 管中窥豹——从对象的生命周期梳理JVM内存结构、GC调优、类加载、AOP编程及性能监控
			如题,本文的宗旨既是透过对象的生命周期,来梳理JVM内存结构及GC相关知识,并辅以AOP及双亲委派机制原理,学习不仅仅是海绵式的吸收学习,还需要自己去分析why,加深对技术的理解和认知,祝大家早日走上 ... 
- 插入排序的优化非希尔【不靠谱地讲可以优化到O(nlogn)】 USACO 丑数
			首先我们先介绍一下普通的插排,就是我们现在一般写的那种,效率是O(n^2)的. 普通的插排基于的思想就是找位置,然后插入进去,其他在它后面的元素全部后移,下面是普通插排的代码: #include< ... 
- Python3.5爬虫统计AcFun所有视频,并按各个类别进行Top100排序展示
			前(b)言(b): 前段时间对Python产生了浓厚的兴趣,所以决定入门学习了1个多月,后来某时我需要对tomcat做一个压力测试,于是我想到了用Python写一个压力测试的脚本吧!最后捣鼓出了一个脚 ... 
- 使用mysql索引技巧及注意事项
			一.索引的作用 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,所以查询语句的优化显然是重中之重. 在数据 ... 
- mysql数据库实操笔记20170419
			一.insert与replace区别: insert:当表里有字段设置了主键或者唯一时,插入重复的唯一或主键字段值是不能执行的: replase:当表里有字段设置了主键或者唯一时,插入重复的唯一或主键 ... 
