本文共 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/