不得不说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避坑相关推荐

  1. Deep Reinforcement Learning: Pong from Pixels翻译和简单理解

    原文链接: http://karpathy.github.io/2016/05/31/rl/ 文章目录 原文链接: 前言 Policy-Gradient结构流程图 Deep Reinforcement ...

  2. android 点击事件消费,Android View事件分发和消费源码简单理解

    Android View事件分发和消费源码简单理解 前言: 开发过程中觉得View事件这块是特别烧脑的,看了好久,才自认为看明白.中间上网查了下singwhatiwanna粉丝的读书笔记,有种茅塞顿开 ...

  3. 【转载】Deep learning:十九(RBM简单理解)

    Deep learning:十九(RBM简单理解) 这篇博客主要用来简单介绍下RBM网络,因为deep learning中的一个重要网络结构DBN就可以由RBM网络叠加而成,所以对RBM的理解有利于我 ...

  4. 学习:双机热备、集群、负载均衡、SQL故障转移群集简单理解(转)

    双机热备.集群.负载均衡.SQL故障转移群集简单理解平常,大家常提到几个技术名词:双机热备.集群.负载均衡.SQL故障转移群集.这里,就我的理解,和大家简单探讨下,有不足或错误之处还请各位指出! 这些 ...

  5. python编程例子 输入 输出-推荐 :手把手教你用Python创建简单的神经网络(附代码)...

    原标题:推荐 :手把手教你用Python创建简单的神经网络(附代码) 作者:Michael J.Garbade:翻译:陈之炎:校对:丁楠雅 本文共2000字,9分钟. 本文将为你演示如何创建一个神经网 ...

  6. 字符串匹配算法Java_如何简单理解字符串匹配算法?

    这篇文章来说说如何简单理解KMP,BM算法.之前看过一些文章说,KMP算法很难理解. 可我并不觉得. 我反而觉得它容易理解.平时我们写java代码的时候, 判断一个字符串是否存在包含另一个字符串都是直 ...

  7. python yield的简单理解

    2019独角兽企业重金招聘Python工程师标准>>> yield是个生成器,它可以使一个方法变成可迭代的方法,每次迭代返回yield后面的值 简单理解: >>>d ...

  8. linun——SElinux的简单理解

    SElinux简单理解 一.什么是SElinux? SELinux 全称 Security Enhanced Linux (安全强化 Linux),是 MAC (Mandatory Access Co ...

  9. git pull 是到工作区还是暂存区_每天一Git之简单理解工作区和暂存区

    每天一Git之简单理解工作区和暂存区 1. 工作区与暂存区命令初体验 1.1. 暂存区文件与文件夹管理 [root@number ~]# cd GitDir/git_learning/ [root@n ...

最新文章

  1. android适配右到左布局注意事项
  2. python3视频教程-python3入门视频教程
  3. 【模拟】P1424 小鱼的航程(改进版)
  4. 利用计算机进行信息加工正确的说法,信息技术习题1(1-50)
  5. dubbo 使用 filter 报错解决
  6. java语言发展历史_Java编程语言的历史和未来
  7. CodeSmith注册机,支持5.2.2和5.2.1版
  8. Linux 文件夹权限
  9. Linux内核驱动模块示例--Helloword及Makefile
  10. 软件项目管理 2.3.项目章程
  11. 三菱plc指令dediv_三菱plc指令tcmp的用法
  12. 图解大数据 | 大数据分析挖掘-Spark初步
  13. 使用python破解zip、rar压缩包密码
  14. 关于安装ANACONDA遇到的无法定位动态链接库问题
  15. CentOS7.4通过ssh连接到服务器的时候特别慢
  16. 运动世界校园【夜神模拟器——步频脚本一键导入】
  17. 【详细七层】OSI 网络模型,七层网络模型
  18. hao123.com上的邮箱登录
  19. 使用zbar识别二维码
  20. 巅峰诞生虚伪的拥护,黄昏见证虔诚的使徒

热门文章

  1. Wampserver图标是橙色的问题解决方案
  2. html中斜体样式怎么写,CSS font-style斜体字体倾斜体样式
  3. 读书项目:epubjs阅读器引擎介绍
  4. 免费申请通配符ssl证书https证书
  5. 小程序(四)小程序生命周期
  6. 整理:数据库设计的六个阶段详解
  7. IBM LinuxONE Community Cloud 免费试用申请教程
  8. 怎么连接亚马逊的linux云服务器配置,使用 亚马逊云 AWS 配置服务器并使用 xshell 远程连接...
  9. matlab中找出能被5整除的数,matlab~~求解1到m以内,所有能被3整除的数。
  10. excel 怎么计算单元格个数