已知一个总长度不超过10000的字符串,字符串中只包含大写字母“A—Z”、小写字母“a—z”和空格‘ ’。空格用于分割单词,空格的个数不超过1000个。你的任务是将字符串中用空格分隔的单词打印出来。 你要按照如下要求完成任务: 1.利用指针数组指向每个单词的开始位置。 2.把字符串中单词结束后的空格改为“\0”,然后使用指针数组将每个单词打印出来。 此题要求用函数完成。
函数接口定义:
函数原型如下:
int getString( char * source , char *strPtr[] ) ;
其中 source
和 strPtr
都是用户传入的参数。 source
为待处理字符串; strPtr
是保存各个单词开始位置的指针数组。函数返回值为单词的个数。
裁判测试程序样例:
函数被调用进行测试的例子如下:
#include<stdio.h>
int getString( char * source , char *strPtr[] ) ;
int main()
{
char str[100005];
char *strPtr[1005]={0};
int i, num ;
gets(str);
num = getString( str , strPtr ) ;
for( i = 0 ; i < num ; i++ )
puts(strPtr[i]);
return 0;
}
/* 请在这里填写答案 */
输入样例:
You are great
结尾无空行
输出样例:
You
are
great
结尾无空行
int getString( char * source , char *strPtr[] )
{
int i,j=0;
while(source[i]==' ')
{
source[i]=='\0';
i++;
}
strPtr[j]=&source[i];
for(;i<100005;i++)
{
if(source[i]=='\0')
break;
while(source[i]==' ')
{
source[i]='\0';
if(source[i]=='\0'&&source[i+1]!=' '&&source[i+1]!='\0')
{
j++;
strPtr[j]=&source[i+1];
}
}
}
return j+1;
}