不厭徐何 2023-03-23 23:07 采纳率: 56.5%
浏览 28
已结题

关于#c语言#的问题

输出字符串中最长的单词,不知道哪里错了


#include <stdio.h>
#include <string.h>
int main(){
    char str[100];
    printf("输入字符串:");
    gets(str);
    printf("最长的单词是:");
    int i;
    int letter(char c);
    int longest(char arr[]);
    for(i=longest(str);letter(str[i]);i++){
        printf("%c",str[i]);
    }     
    return 0;
}
int letter(char c){      //判断是否是英文字母 
    if(c>='a'&&c<='z'||c>='A'&&c<='Z') return 1;
    else return 0;
}
int longest(char arr[]){
    int flag=1;//表示将要读入的字母是起始位置的
    int i;
    int point=0;//表示当前单词的起始下标  
    int num=0;//表示当前单词累计的字母个数
    int maxlength=0;//表示最长单词的长度
    int place=0;//表示最长单词的起始位置
    for(i=0;i<strlen(arr);i++){
        if(letter(arr[i])){
            if(flag){
                point=i;
                flag=0;
            }
            num++;
        }
        else {
            flag=1;
            if(num>=maxlength){
                maxlength=num;
                place=point;
            }
            num=0;             
        } 
    } 
    return place; 
}
  • 写回答

3条回答 默认 最新

  • threenewbee 2023-03-23 23:46
    关注
    int longest(char arr[]) {
        int i = 0, start = 0, max_len = 0, max_start = 0;
        int len = strlen(arr);
        
        while (i < len) {
            while (i < len && isspace(arr[i])) {
                i++;
            }
            start = i;
            while (i < len && !isspace(arr[i])) {
                i++;
            }
            int word_len = i - start;
            if (word_len > max_len) {
                max_len = word_len;
                max_start = start;
            }
        }
        return max_start;
    }
    
    
    评论 编辑记录

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 7月4日
  • 创建了问题 3月23日

悬赏问题

  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集