不得不说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. 挡不住的AI成熟趋势
  2. python编写程序-30分钟学会用Python编写简单程序
  3. 游戏AI研究(三):路径规划
  4. C++学习笔记-----永远不要在派生类中改变虚函数的默认参数值
  5. mysql 人名用什么类型_如何选择合适的MySQL数据类型
  6. 漫步微积分一 —— 引言
  7. java 关键字是运算符_Java的super关键字与instanceof运算符使用方法
  8. php target标签,为Typecho文章页url标签添加nofollow和target属性
  9. Swift - 多线程实现方式(3) - Grand Central Dispatch(GCD)
  10. php json json_unescaped_unicode,php中json_encode不兼容JSON_UNESCAPED_UNICODE的解决方案
  11. 来自一个从事单片机工作中遇到的真人真事,单片机从业者可以借鉴
  12. 进程管理之工作管理详解(job control)
  13. pdf分页分片预览,pdf截取,pdf转图片
  14. Git 使用 — Git下载与安装
  15. 电机控制进阶3——PID串级控制(附全套代码下载)
  16. 今日头条笔试面试大全
  17. idea 的Igonre 设置
  18. node.js毕业设计鲸落图书商城小程序LW(源码+程序+LW+部署)
  19. 计算机上海交大考研有学硕吗,2021上海交大考研:学硕专硕的区别
  20. 趣味算法 四个点在同一个半圆的概率

热门文章

  1. Linux提权(su和sudo)以及用户的权限(ugo)(超详细操作解释)
  2. kaggle phone verify 收不到验证码
  3. TDengine Unable to resolve FQDN
  4. 软件测试的7项基本原则
  5. 基于OpenCV的立体相机标定StereoCalibration与目标三维坐标定位
  6. 服务器支持ashx,如何在服务器上找到.ashx文件的位置
  7. Ubuntu都2104了,docker怎么还在安装?
  8. 《画解数据结构》(0 - 4)- 逻辑结构
  9. IDEA的常用快捷键以及提示信息
  10. Scanner 扫描文件内容 读取文件