6-3 实验10_5_指针数组初步 (100分)
已知一个总长度不超过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)
{
for(i=0;*(source+i)&&*(source+i)!=' ';i++)
{
if(*(source+i+1)=='\0') //最后一个单词末尾不是空格
{
strPtr[j]=source;
j++;
return j;
}
if(*(source+i+1)==' ')
{
*(source+i+1)='\0';
strPtr[j]=source;
j++;
}
}
source=source+i+1;
}
return j;
}