博客
关于我
PTA 7-1 jmu-ds-最长数字序列 (20 分)
阅读量:743 次
发布时间:2019-03-22

本文共 1884 字,大约阅读时间需要 6 分钟。

原题如下:

输入一个字符串,求该字符串中最长连续数字序列出现的起始位置及其长度。

输入格式:

输入一个字符串,可包含空格。

输出格式:

输出内容:最长数字序列起始位置和长度空格隔开。输出尾部不能有空格。输入空串,输出"NULL"

输入样例:

123ab12345a

输出样例:

5 5

这个题的意思其实只是找出字符串中最长的数字序列即可,而数字序列不一定是连续的......开始的时候误解了题的意思,以为数字序列也是连续的,所以一直无法通过测试....

正确代码如下:

#include
#include
#include
using namespace std;int main(){ string s; getline(cin,s); int maxindex = 0,maxlen = 0; int len = 0; if(s.length()==0) { cout << "NULL"; return 0; } for(int i = 0;i < s.length();i++) { if(s[i]>='0'&&s[i]<='9') { len++; if(s[i+1]=='\0') { maxlen = len; maxindex = i-len+1; } } else { if(len >= maxlen) { maxlen = len; maxindex = i-len; } len = 0; } } printf("%d %d",maxindex,maxlen); return 0;}

 既然都已经写了读取连续数字序列的代码,也贴到这了...

#include
#include
#include
using namespace std;int main(){ string s; getline(cin,s); int maxindex = 0,maxlen = 0; int len = 0; if(s.length()==0) { cout << "NULL"; return 0; } for(int i = 0;i < s.length();i++) { if(s[i]>='0'&&s[i]<='9') { if(s[i+1]-s[i]==1) { len++; if(i==s.length()-2) { if(len >= maxlen) { maxlen = len+1; maxindex = i-len+1; } break; } } else { if(len >= maxlen) { maxlen = len+1; maxindex = i-len; } len = 0; } } } printf("%d %d",maxindex,maxlen); return 0;}

 

转载地址:http://wubwk.baihongyu.com/

你可能感兴趣的文章
MySQL单实例或多实例启动脚本
查看>>
MySQL压缩包方式安装,傻瓜式教学
查看>>
MySQL原理、设计与应用全面解析
查看>>
MySQL原理简介—1.SQL的执行流程
查看>>
MySQL参数调优详解
查看>>
mysql参考触发条件_MySQL 5.0-触发器(参考)_mysql
查看>>
MySQL及navicat for mysql中文乱码
查看>>
MySqL双机热备份(二)--MysqL主-主复制实现
查看>>
MySql各种查询
查看>>
mysql同主机下 复制一个数据库所有文件到另一个数据库
查看>>
mysql启动以后会自动关闭_驾照虽然是C1,一直是开自动挡的车,会不会以后就不会开手动了?...
查看>>
mysql启动和关闭外键约束的方法(FOREIGN_KEY_CHECKS)
查看>>
Mysql启动失败解决过程
查看>>
MySQL启动失败:Can't start server: Bind on TCP/IP port
查看>>
mysql启动报错
查看>>
mysql启动报错The server quit without updating PID file几种解决办法
查看>>
MySQL命令行登陆,远程登陆MySQL
查看>>
mysql命令:set sql_log_bin=on/off
查看>>
mySQL和Hive的区别
查看>>
MySQL和Java数据类型对应
查看>>