题目描述:
通过键盘输入任意一个字符串序列,字符串可能包含多个子串,子串以空格分隔。请编写一个程序,自动分离出各个子串,并使用’,’将其分隔,并且在最后也补充一个’,’并将子串存储。
如果输入“abc def gh i d”,结果将是abc,def,gh,i,d,
要求实现函数:
void DivideString(const char *pInputStr, long lInputLen, char *pOutputStr);
通过键盘输入任意一个字符串序列,字符串可能包含多个子串,子串以空格分隔。请编写一个程序,自动分离出各个子串,并使用’,’将其分隔,并且在最后也补充一个’,’并将子串存储。
如果输入“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 <iostream>
#define N 100
using namespace std;
void DivideString(const char* pInputStr,long lInputLen,char* pOutputStr)
{
int i=0;
while(i<lInputLen)
{
while((pInputStr[i]>='a'&&pInputStr[i]<='z')||(pInputStr[i]>='A'&&pInputStr[i]<='Z'))
{
*pOutputStr=pInput[i];
pOutputStr++;
i++;
}
*pOutputStr=',';
pOutputStr++;
while(pInputStr[i]==' ')
{
i++;
}
}
*pOutputStr='\0';
}
int main()
{
char str[N];
cin.getline(str,N);
int len=strlen(str);
char* s=(char*)malloc(len*sizeof(char));
DivideString(str,len,s);
cout<<s<<endl;
return 0;
}