考上研究僧 2022-02-22 19:07 采纳率: 97.4%
浏览 799
已结题

一个以'.'结尾的简单英文句子,单词之间用空格分隔,没有缩写形式和其它特殊形式。


#include<stdio.h>
int main()
{
    char str[500];
    int i = 0, place, max = 0, count = 0, last_locate;
    gets_s(str);
    while (str[i] != '.')
    {
        if (str[i] == ' ')
            i++;
        place = i;
        for (; str[i] != ' '; i++)
            if (str[i] >= 'a' && str[i] <= 'z' || str[i] >= 'A' && str[i] <= 'Z')
                count++;
        if (count > max)
        {
            max = count;
            last_locate = place;
        }
        count = 0;
    }
    for (i = last_locate; str[i] != ' ' && str[i] != '.'; i++)
        printf("%c", str[i]);
    return 0;
}

报错说这句for (; str[i] != ' '; i++)内存访问冲突,感觉没问题啊?

  • 写回答

4条回答 默认 最新

  • 是小明同学呀 2022-02-22 19:38
    关注

    你这个报错是因为你软件进入死循环了,索引i一直增加,然后就指向一些保护地址了,所以就报错了。
    你代码有问题

    #include<stdio.h>
    int main()
    {
        char str[500];
        int i = 0, place, max = 0, count = 0, last_locate;
        gets_s(str);
        while (str[i] != '.')//你本意是用这个来检测结束符,但是你下面Line13又嵌套了一个for循环增加i,导致你不能检查每一个字符,错过“.”进死循环
        {
            if (str[i] == ' ')
                i++;
            place = i;
            for (; str[i] != ' '; i++)//这里的条件也又问题,如果后面没有空格符了也会进死循环
            {
                if (str[i] >= 'a' && str[i] <= 'z' || str[i] >= 'A' && str[i] <= 'Z')
                    count++;
            }
            if (count > max)
            {
                max = count;
                last_locate = place;
            }
            count = 0;
        }
        for (i = last_locate; str[i] != ' ' && str[i] != '.'; i++)
            printf("%c", str[i]);
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月2日
  • 已采纳回答 2月22日
  • 创建了问题 2月22日

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签天线)