qq_43397803
qq_43397803
采纳率100%
2018-12-06 09:36

请路过的大神有时间帮忙看看,搞不懂if语句运行后就无限循环

已采纳

图片说明

if语句里面的内容运行后就无限循环,真想不通。。。。以下是整个程序的代码:

#include<iostream>
#include<cstring>
using namespace std;
int fn1(char [],char []);//判断输入的有没有两个空格
int main()//让用户按要求输入正确的格式 
{
    char blank[]="  ";
    cout<<"输入用两个空格分隔开的两个字符串\n";
    for(int i=0;i<=0;i++)
    {
        char *input=new char[20];
        cin.get(input,20);
        if(fn1(input,blank))
        {
            i--;
            delete input;
            continue;
        }
        cout<<"输入正确"; 
        delete input; 
    }
    return 0; 
}
int fn1(char judge_input[],char judge_blank[])
{
        for(int i=0;i<10;i++)
        {
            if((strstr(judge_input,judge_blank))==NULL)
            {
                cout<<"输入的格式错误,请重新输入\n";
                return 1;
            }
            if((strstr(judge_input,judge_blank))[i]==' '&&i>=2)
            {
                cout<<"输入的格式错误,请重新输入\n";
                return 1;
            }
            if(i==2)
            {
                return 0;
            }
        }
}
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

4条回答

  • qq_43397803 qq_43397803 3年前

    if(fn1(input,blank))
    {
    i--;
    cin.ignore(22,'\n');
    delete input;
    continue;
    }
    加个cin.ignore(22,'\n'); 问题就解决了。

    点赞 评论 复制链接分享
  • weixin_41461277 _ZGq 3年前

    第一:
    delete input;这一句应该用delete[]运算符,因为前面用的是new[]。
    把那两个 delete input; 换成 delete input[];

    第二:
    input只有20的空间,其中有一个必须是'\0',但是cin.get()一次就读了20个,把'\0'的空间也占了,字符串没有'\0'就会连接上后面的内存。

    点赞 评论 复制链接分享
  • meicuojiushiwoi meicuojiushiwoi 3年前

    图片说明

    点赞 评论 复制链接分享
  • qq_43998339 qq_43998339 3年前

    if里面i--之后又有个continue然后又到for那里去了,for那里有个i++所以i一直等于0

    点赞 评论 复制链接分享

相关推荐