怎么根据此代码实现这个要求呢
#include <stdio.h>#include <string.h>
#include <stdlib.h>
// 实现要求,怎么去掉空格并统计字符串的长度呢,并找出长度最大的字符串
int main()
{
char a="";
char *p={NULL};
char b="";
memset(a,0,sizeof(a));
gets(a);
// 以空格作为分隔符,进行分割
int i=0;
int len=0;
do
{
if(i==0)
{
p=strtok(a," ");
int len=strlen(p);
}
else
{
p=strtok(NULL," ");
if(strlen(p)>len)
{
len=strlen(p);
strcpy(b,p);
}
}
} while (p!=NULL);
int sum=0;
i=0;
while (p!=NULL)
{
printf("%s\n",p);
sum+=strlen(p);
}
printf("%d %s",sum,b);//最后输出
}
例如 My name is Amy
返回 11 name 你的代码存在一些小问题,我一步一步帮你修复一下。首先,你声明了一个字符数组 `a`,但是长度为1,这不够存储字符串。我建议你将它的长度设置得足够大,比如说100。另外,你声明了一个指针数组 `p`,但是没有为它分配内存空间,这会导致程序运行时错误。我推荐你使用动态内存分配来解决这个问题。接下来,你在两处将变量 `len` 声明了两次,这样的话第一个 `len` 变量就会覆盖掉第二个 `len` 变量的值,导致后面的比较不准确。最后,在最后一个 `while` 循环中,你没有更新 `p` 的值,导致循环无法终止。我为你修改了一下代码,请参考:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char a;
char *p = NULL;
char b;
memset(a, 0, sizeof(a));
gets(a);
// 去掉空格并统计字符串的长度
int i = 0;
int len = 0;
do
{
if (i == 0)
{
p = strtok(a, " ");
len = strlen(p);
}
else
{
p = strtok(NULL, " ");
if (p != NULL && strlen(p) > len)
{
len = strlen(p);
strcpy(b, p);
}
}
i++;
} while (p != NULL);
// 输出每个单词
int sum = 0;
p = strtok(a, " ");
while (p != NULL)
{
printf("%s\n", p);
sum += strlen(p);
p = strtok(NULL, " ");
}
printf("%d %s", sum, b);// 最后输出
return 0;
}
现在你可以根据题目的要求输入字符串,然后程序会去掉空格并统计字符串的长度,最后找出长度最大的字符串,并输出每个单词和长度最大的单词。注意,这段代码使用了不建议使用的函数 `gets`,你在实际编程中应该使用更安全的函数 `fgets` 来代替。另外,在使用 `strtok` 函数时,要注意传入的字符串不能是常量字符串,因为 `strtok` 函数会修改传入的字符串。
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 本帖最后由 jackz007 于 2023-12-28 22:56 编辑
#include <stdio.h>
int main(void)
{
char a = "" ,* p ;
int i , k , m , max ;
gets(a) ;
for(i = 0 ; a ; i ++) ; // 【技巧】:在字符串末尾多添加一个空格字符,以便防止遗漏统计最后那个单词
a = ' ' ; // 【技巧】:在字符串末尾多添加一个空格字符,以便防止遗漏统计最后那个单词
a = '\0' ; // 【技巧】:在字符串末尾多添加一个空格字符,以便防止遗漏统计最后那个单词
for(i = k = m = max = 0 ; a ; i ++) {
if(a != ' ') {
m ++ ;
k ++ ;
} else {
a = '\0' ;
if(k > max) {
p = & a ;
max = k ;
}
k = 0 ;
}
}
printf("%d %s\n" , m , p) ;
}
页:
[1]