博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在字符串中找出连续最长的数字串
阅读量:4107 次
发布时间:2019-05-25

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

题目描述:

请一个在字符串中找出连续最长的数字串,并把这个串的长度返回;如果存在长度相同的连续数字串,返回最后一个连续数字串;

注意:

数字串只需要是数字组成的就可以,并不要求顺序,比如数字串“1234”的长度就小于数字串“1359055”,如果没有数字,则返回空字符串(“”)而不是NULL!

样例输入:

abcd12345ed125ss123058789
abcd12345ss54761

样例输出:

输出123058789,函数返回值9
输出54761,函数返回值5

接口说明

函数原型:

unsignedint Continumax(char** pOutputstr,  char* intputstr)

输入参数:

char* intputstr 输入字符串;
输出参数:
char** pOutputstr: 连续最长的数字串,如果连续最长的数字串的长度为0,应该返回空字符串;如果输入字符串是空,也应该返回空字符串;

返回值:

连续最长的数字串的长度

#include 
#include
#include
#define ERR_ARG (-1)#define NO_NUM 1unsigned int continueMax (char **pOutputStr, char *pInputStr){ unsigned int maxLen = 0, tmpLen = 0; char *pTmp = pInputStr; char *pIndex = NULL; printf ("%s\n", pInputStr); if (NULL == pTmp) { *pOutputStr = ""; return NO_NUM; } while (*pTmp != '\0') { if ((*pTmp >= '0') && (*pTmp <= '9')) { ++tmpLen; } else { if (tmpLen >= maxLen) { maxLen = tmpLen; pIndex = pTmp - tmpLen; } tmpLen = 0; } pTmp++; } *pOutputStr = (char*)malloc((maxLen+1) * sizeof(char)); strncpy (*pOutputStr, pIndex, maxLen); printf ("%d %s\n",maxLen, *pOutputStr); return maxLen;}int main (int argc, char* argv[]){ char *pOutput = NULL; char *pInput = "qwff234567689jjbcdd1456785566ddfdc"; if (argc < 2) { printf ("Usage:\n"); printf (" ./filename
\n"); return ERR_ARG; } continueMax (&pOutput, argv[1]); free (pOutput); continueMax (&pOutput, pInput); free (pOutput);}
VirtualBox:160518$ gcc continueMax.c -o conVirtualBox:160518$ ./con qr34567sdfgqr34567sdfg5 34567qwff234567689jjbcdd1456785566ddfdc10 1456785566VirtualBox:160518$ ./con qr34567sdfg12345sdfghqr34567sdfg12345sdfgh5 12345qwff234567689jjbcdd1456785566ddfdc10 1456785566

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

你可能感兴趣的文章
MySQL Tricks1
查看>>
python 变量作用域问题(经典坑)
查看>>
pytorch
查看>>
pytorch(二)
查看>>
pytorch(三)
查看>>
pytorch(四)
查看>>
pytorch(5)
查看>>
pytorch(6)
查看>>
opencv 指定版本下载
查看>>
ubuntu相关
查看>>
C++ 调用json
查看>>
nano中设置脚本开机自启动
查看>>
动态库调动态库
查看>>
Kubernetes集群搭建之CNI-Flanneld部署篇
查看>>
k8s web终端连接工具
查看>>
手绘VS码绘(一):静态图绘制(码绘使用P5.js)
查看>>
手绘VS码绘(二):动态图绘制(码绘使用Processing)
查看>>
基于P5.js的“绘画系统”
查看>>
《达芬奇的人生密码》观后感
查看>>
论文翻译:《一个包容性设计的具体例子:聋人导向可访问性》
查看>>