C语言输出一行字符串中最长的单词
#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
}
2024-07-18 广告
#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;
}
#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;
}
#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);
}
//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");
}