不得不说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. Javascript的FSO功能
  2. jupyter notebook 更改工作目录
  3. 如何使用Laravel Debugbar?
  4. .Net开发笔记(十九) 创建一个可以可视化设计的对象
  5. SUSE10下配置FTP服务
  6. LeetCode 848. 字母移位(前缀和+取模)
  7. python echo命令_如何用Python调用外部命令
  8. C#使用ListView更新数据出现闪烁解决办法
  9. TensorFlow笔记(11) GoolgeNet
  10. 计算机编程学英语词汇,计算机编程英语词汇大全
  11. 用汉堡包的方式评价一下自己的合作伙伴
  12. (转)美国进入智能投顾竞争时代
  13. 软件测试工程师自我介绍范文_软件测试自我介绍范文
  14. 微信支付退款接口证书使用
  15. 迪米特法则 php,迪米特法则(The Law of Demeter) -解道Jdon
  16. 2017070506嵌入式开发系统概述和开发工具的使用
  17. 好好生活,总会遇见美好事物
  18. 杭州区块链技术与应用联合会简报
  19. Debian6.0安装后系统基本配置
  20. 简陋无匹的python学生信息管理系统

热门文章

  1. ensp防火墙基础配置
  2. 领域驱动/DDD模型初识
  3. 37. flex布局
  4. 高精度算法——高精度加法
  5. sklearn专题一:决策树
  6. html 下拉框设置名称,html下拉菜单怎么做?高手教你如何在HTML和CSS中创建下拉菜单...
  7. 日媒称IPHONE6不是圆角矩形 将配备曲面屏幕
  8. android灰字体什么意思,Android 6.0状态栏使用灰色文字和图标
  9. 如何用Python在图片上绘制BoundingBox
  10. 方舟服务器设置文档,方舟生存进化参数文件ini怎么设置_方舟生存进化参数文件ini设置教程_玩游戏网...