首页 > 代码库 > 华为机试—子串分离
华为机试—子串分离
题目描述:
通过键盘输入任意一个字符串序列,字符串可能包含多个子串,子串以空格分隔。请编写一个程序,自动分离出各个子串,并使用’,’将其分隔,并且在最后也补充一个’,’并将子串存储。
如果输入“abc def gh i d”,结果将是abc,def,gh,i,d,
要求实现函数:
void DivideString(const char *pInputStr, long lInputLen, char *pOutputStr);
【输入】 pInputStr: 输入字符串
lInputLen: 输入字符串长度
【输出】 pOutputStr: 输出字符串,空间已经开辟好,与输入字符串等长;
【注意】只需要完成该函数功能算法,中间不需要有任何IO 的输入输出
示例
输入:“abc def gh i d”输出:“abc,def,gh,i,d,”
#include<string.h> #include<stdio.h> void DivideString(const char *pInputStr, long lInputLen, char *pOutputStr) { int j=0; char pre='*'; for(long i=0;i<lInputLen;++i) { if(pInputStr[i]!=' ') { pOutputStr[j++]=pInputStr[i]; } else if(pre!=' ') { pOutputStr[j++]=','; } pre=pInputStr[i]; } pOutputStr[j++]=','; pOutputStr[j++]='\0'; } int main(int argc, char *argv[]) { char input[200]; char output[200]; while(gets(input)) { DivideString(input ,strlen(input), output); printf("%s\n",output); } return 0; }
华为机试—子串分离
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。