C语言输出一行字符串中最长的单词

#include<stdio.h>
#include<string.h>
void main()
{
void function(char str[]);
char str[100];
printf("请输入一行字符串:");
gets(str);
function(str);
}

void function(char str[])
{
int i=0,j=0,k=0;
char str1[30][30],str2[100];
for(i=0;str[i]!='\0';i++)
{
if((str[i]>='a' && str[i]<='z') || (str[i]>='A' && str[i]<='Z'))
{
str1[j][k]=str[i];
k++;
}
else
{
j++;
k=0;
}
}
strcpy(str2,str1[0]);
for(i=0;i<=28;i++)
{
if(strlen(str1[i+1])>strlen(str1[i]))
strcpy(str2,str1[i+1]);
}
printf("该字符串中最长的单词是:%s\n",str2);
}

这程序错在哪?为什么会输出一大堆“烫”字,而不能输出一行字符串中最长的单词?

代码如下:

#包括< stdio, h >

# include < string。H >

Voidmain()

字符c[50];

Voidf(charc[50]);//没有返回值,直接用函数f打印结果。

(c);

F(c);

Voidf(charc[50])

Intlen=0,lenth=0,I,flag=0;

For(I=0;C(我)!='\0';我++)

如果(c[我]!='')

Len++;

If(c[I]=='')

If (len > lenth)

长度=兰;

国旗=i-lenth;//当有一个新的最长的字符串时,使用flag记录字符串开始下标

Len=0;

If (len > lenth)

长度=兰;

国旗=i-lenth;//以同样的方式

Printf("最长的子串是%d字符,子串是:",lenth);//打印子串的长度

For (I = flag;I < flag + lenth;i++)//将子字符串从flag输出到flag + lenth-1

Printf("%c",[I]c);

Printf("\n");//换行

扩展资料:

1.返回意味着从被调用的函数继续执行到主函数。Return可以伴随一个返回值,返回值可以是常量、变量或表达式。

2.操作:结束正在运行的函数并返回该函数的值。

3.返回值:

返回值可以是各种数据类型,例如:int、float、ouble、char、a[](数组)、*a(指针)、

结构或类(c++)返回类型指定返回后要添加的金额的类型,如果返回类型被声明为void,则不需要返回值。PublicstaticvoidMain()//programentry只能被声明为void和int的返回

{

//没有返回值

}

公共静态空隙(mm)

{

返回;//在某些情况下,在一个voidmethod中,需要跳出来,你可以直接使用return,不能在后面添加任何数量

}

公共静态intcc()

{

321的回归;因为返回类型声明为int,所以返回一个整数

}

公共静态字符串MSMSM()

{

返回“asdfhasjghdg”;因为返回类型被声明为string,所以返回一个string

}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2015-05-25
#include <stdio.h>
#include <string.h>
//用于判断字符是否是英文字节
int word(char c)
{
if((c>='a'&&c<='z')||(c>='A'&&c<='Z')) return 1;
else return 0;
}
int longest(char str[]) 
{
int i,flag=1,len=0,point,max_len=0,max_point;
//遍历字符
for(i=0;i<=strlen(str);i++)
{
//判断是否为英文
if(word(str[i]))     
{
if(flag==1)       
{
//单词第一个找到后改变标志
point=i;       
flag=0;
}
else len++;      //开始对这个单词长度进行累加
}
else           //非英文字母
{
//等待第一个英文字母的出现
//所以flag=1(要是下一个是英文字母的话就能执行上面的if)
flag=1;       
//之前累加的单词长度是否比上一个单词更长
//(第一次的话max_len初始化为0,len必大于max_len)
if(len>max_len)
{
//将单词长度保存下来
max_len=len;
//将最长单词的第一个英文字母在字符串中的位置保存下来
max_point=point;
}
len=0;
}
}
return (max_point);
}
int main()
{
int word(char c);
int longest(char str[]);
int i;
char str[80];
printf("输入一行字符串\n\n");
gets(str);
printf("\n\n最长的单词为:\n\n");
for(i=longest(str);word(str[i]);i++)
printf("%c",str[i]);
printf("\n");
return 0;
}

第2个回答  2020-05-14

#include <stdio.h>
#include <string.h>
//用于判断字符是否是英文字节
int word(char c)
{
if((c>='a'&&c<='z')||(c>='A'&&c<='Z')) return 1;
else return 0;
}
int longest(char str[]) 
{
int i,flag=1,len=0,point,max_len=0,max_point;
//遍历字符
for(i=0;i<=strlen(str);i++)
{
//判断是否为英文
if(word(str[i]))     
{
if(flag==1)       
{
//单词第一个找到后改变标志
point=i;       
flag=0;
}
else len++;      //开始对这个单词长度进行累加
}
else           //非英文字母
{
//等待第一个英文字母的出现
//所以flag=1(要是下一个是英文字母的话就能执行上面的if)
flag=1;       
//之前累加的单词长度是否比上一个单词更长
//(第一次的话max_len初始化为0,len必大于max_len)
if(len>max_len)
{
//将单词长度保存下来
max_len=len;
//将最长单词的第一个英文字母在字符串中的位置保存下来
max_point=point;
}
len=0;
}
}
return (max_point);
}
int main()
{
int word(char c);
int longest(char str[]);
int i;
char str[80];
printf("输入一行字符串\n\n");
gets(str);
printf("\n\n最长的单词为:\n\n");
for(i=longest(str);word(str[i]);i++)
printf("%c",str[i]);
printf("\n");
return 0;
}

第3个回答  2009-05-31
/*修改好了 注释部分为修改位置 "//"为添加部分*/

#include<stdio.h>
#include<string.h>

void function(char str[]); /*函数声明再外面*/

void main()
{

char str[100];
printf("请输入一行字符串:");
gets(str);
str[strlen(str)]='#';

function(str);
}

void function(char str[])
{
int i=0,j=0,k=0;
char str1[30][30],str2[100];
int state = 0; //设制一个状态记录str[i]是不是字母 0表示不是 1 表示是

for(i=0;str[i]!='\0';i++)
{
if((str[i]>='a' && str[i]<='z') || (str[i]>='A' && str[i]<='Z'))
{
str1[j][k]=str[i];
k++;
str1[j][k] ='\0'; /*字符串都以'\0'结尾所以每次都保持str1[i]是一个字符串, 复制给str2就不会出现少'\0'的情况啦*/
state = 1; //及时设置状态
}
else
{

if(state == 1) {j++;} //仅仅让单词存进去 别的字符就别存到str1中了
state = 0; //及时设置状态
k=0;
}
}

strcpy(str2,str1[0]);

for(i=0;i<j;i++) /*只有j个有效字符串*/
{
if(strlen(str1[i])>strlen(str2)) /*总是让str2保持是最长的字符串*/

strcpy(str2,str1[i]);
}

printf("该字符串中最长的单词是:%s\n",str2);
}本回答被提问者采纳
第4个回答  2009-05-31
送你一个简单一点的程序
//C语言输出一行字符串中最长的单词,原理,一个单词一个单词的试,记录每个单词的长度与原来的比较
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
main()
{ char s[1000];
gets(s);
printf("\n这个这串是:%s\n",s);
int start,i=0,max=0,z=0,big=0;
while(s[i]!='\0')
{int total=0;
if((s[i]>='a' && s[i]<='z') || (s[i]>='A' && s[i]<='Z'))
{ start=i;z++;
while((s[i]>='a' && s[i]<='z') || (s[i]>='A' && s[i]<='Z'))
{total++;i++;}
printf("\n第%d串长是:%d\n",z,total);
if(total>big)
{max=start;big=total;}
}
else
i++; }
i=max;
while((s[i]>='a' && s[i]<='z') || (s[i]>='A' && s[i]<='Z'))
{printf("%c",s[i]);i++;}
system("pause");
}
相似回答