简单理解hduoj 1106 附ac题解以及Presentation Error避坑
不得不说hduoj真的严,这题首先自己没有考虑特殊情况,其次因为格式问题Presentation Error。
注意:出现Presentation Error,可以恭喜你了,题解应该没问题,就是空行,还有空格这些问题!!
题目:
输入一行数字,如果我们把这行数字中的‘5’都看成空格,那么就得到一行用空格分割的若干非负整数(可能有些整数以‘0’开头,这些头部的‘0’应该被忽略掉,除非这个整数就是由若干个‘0’组成的,这时这个整数就是0)。你的任务是:对这些分割得到的整数,依从小到大的顺序排序输出。Input
输入包含多组测试用例,每组输入数据只有一行数字(数字之间没有空格),这行数字的长度不大于1000。 输入数据保证:分割得到的非负整数不会大于100000000;输入数据不可能全由‘5’组成。Output
对于每个测试用例,输出分割得到的整数排序的结果,相邻的两个整数之间用一个空格分开,每组输出占一行。Sample Input0051231232050775Sample Output0 77 12312320
题解:
#include <vector>
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;bool cmp(int a,int b){return a<b;
}int main(){string s;while(cin>>s){vector<long long> res;long long len = s.size();//如果尾部没有,则添加字符5 if(s[len-1]!='5')s.push_back('5'); len = s.size();long long sum = 0;long long k;for(int i=0;i<len;i++){if(s[i]=='5'){//如果出现连续的5或者出现在了第一位则跳过本次循环if(s[i-1]=='5'||i-1<0) continue;//k为数位 for(int j=i-1,k=1;j>=0&&s[j]!='5';j--,k*=10){sum +=(s[j]-48)*k;}//cout<<sum<<'f'<<endl;res.push_back(sum);sum=0;}} sort(res.begin(),res.end(),cmp);long long sz = res.size();for(int i=0;i<sz-1;i++){cout<<res[i]<<" ";}cout<<res[sz-1];cout<<endl;}return 0;
}
思路:
这里的思路就是5做分割然后就从i - 1往前遍历到上一个5,每次得出一个数(两个5之间的那个数),压入res题解。
值得注意的有几点:
- 首先我们得判断最后一位是否为字符5,没有的话要加上。(方便得出题解)然后重新获取字符串长度。
- 然后就是注意边界情况,如果我们的5出现在了字符串的第一位直接跳过。
- 还有一点就是考虑连续的5,我这里是直接判断i-1是否为5
最后就是关于Presentation Error:
我开始就是尾部多一个空格,直接换行,就Presentation Error。百度了下(还好有他),发现出现Presentation Error就基本是格式化问题!
然后我把最后一个字符单独输出,接下来换行。然后就ac了!
不懂的话就评论区问我ou!!
简单理解hduoj 1106 附ac题解以及Presentation Error避坑相关推荐
- Deep Reinforcement Learning: Pong from Pixels翻译和简单理解
原文链接: http://karpathy.github.io/2016/05/31/rl/ 文章目录 原文链接: 前言 Policy-Gradient结构流程图 Deep Reinforcement ...
- android 点击事件消费,Android View事件分发和消费源码简单理解
Android View事件分发和消费源码简单理解 前言: 开发过程中觉得View事件这块是特别烧脑的,看了好久,才自认为看明白.中间上网查了下singwhatiwanna粉丝的读书笔记,有种茅塞顿开 ...
- 【转载】Deep learning:十九(RBM简单理解)
Deep learning:十九(RBM简单理解) 这篇博客主要用来简单介绍下RBM网络,因为deep learning中的一个重要网络结构DBN就可以由RBM网络叠加而成,所以对RBM的理解有利于我 ...
- 学习:双机热备、集群、负载均衡、SQL故障转移群集简单理解(转)
双机热备.集群.负载均衡.SQL故障转移群集简单理解平常,大家常提到几个技术名词:双机热备.集群.负载均衡.SQL故障转移群集.这里,就我的理解,和大家简单探讨下,有不足或错误之处还请各位指出! 这些 ...
- python编程例子 输入 输出-推荐 :手把手教你用Python创建简单的神经网络(附代码)...
原标题:推荐 :手把手教你用Python创建简单的神经网络(附代码) 作者:Michael J.Garbade:翻译:陈之炎:校对:丁楠雅 本文共2000字,9分钟. 本文将为你演示如何创建一个神经网 ...
- 字符串匹配算法Java_如何简单理解字符串匹配算法?
这篇文章来说说如何简单理解KMP,BM算法.之前看过一些文章说,KMP算法很难理解. 可我并不觉得. 我反而觉得它容易理解.平时我们写java代码的时候, 判断一个字符串是否存在包含另一个字符串都是直 ...
- python yield的简单理解
2019独角兽企业重金招聘Python工程师标准>>> yield是个生成器,它可以使一个方法变成可迭代的方法,每次迭代返回yield后面的值 简单理解: >>>d ...
- linun——SElinux的简单理解
SElinux简单理解 一.什么是SElinux? SELinux 全称 Security Enhanced Linux (安全强化 Linux),是 MAC (Mandatory Access Co ...
- git pull 是到工作区还是暂存区_每天一Git之简单理解工作区和暂存区
每天一Git之简单理解工作区和暂存区 1. 工作区与暂存区命令初体验 1.1. 暂存区文件与文件夹管理 [root@number ~]# cd GitDir/git_learning/ [root@n ...
最新文章
- android适配右到左布局注意事项
- python3视频教程-python3入门视频教程
- 【模拟】P1424 小鱼的航程(改进版)
- 利用计算机进行信息加工正确的说法,信息技术习题1(1-50)
- dubbo 使用 filter 报错解决
- java语言发展历史_Java编程语言的历史和未来
- CodeSmith注册机,支持5.2.2和5.2.1版
- Linux 文件夹权限
- Linux内核驱动模块示例--Helloword及Makefile
- 软件项目管理 2.3.项目章程
- 三菱plc指令dediv_三菱plc指令tcmp的用法
- 图解大数据 | 大数据分析挖掘-Spark初步
- 使用python破解zip、rar压缩包密码
- 关于安装ANACONDA遇到的无法定位动态链接库问题
- CentOS7.4通过ssh连接到服务器的时候特别慢
- 运动世界校园【夜神模拟器——步频脚本一键导入】
- 【详细七层】OSI 网络模型,七层网络模型
- hao123.com上的邮箱登录
- 使用zbar识别二维码
- 巅峰诞生虚伪的拥护,黄昏见证虔诚的使徒
热门文章
- Wampserver图标是橙色的问题解决方案
- html中斜体样式怎么写,CSS font-style斜体字体倾斜体样式
- 读书项目:epubjs阅读器引擎介绍
- 免费申请通配符ssl证书https证书
- 小程序(四)小程序生命周期
- 整理:数据库设计的六个阶段详解
- IBM LinuxONE Community Cloud 免费试用申请教程
- 怎么连接亚马逊的linux云服务器配置,使用 亚马逊云 AWS 配置服务器并使用 xshell 远程连接...
- matlab中找出能被5整除的数,matlab~~求解1到m以内,所有能被3整除的数。
- excel 怎么计算单元格个数