鱼C论坛

 找回密码
 立即注册
查看: 1186|回复: 2

[已解决]c,没有报错,运行结果前一步用printf打印还是对的,最后一步打印出来就不对

[复制链接]
发表于 2020-11-4 20:09:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include <stdio.h>

// 分割字符串。用户输入一个英文句子,你的程序将这个字符串按空格进行分割,
//返回由单词组成的二维数组
//不论是一个空格还是多个空格,你的程序都能够正确识别出单词来
int main()
{
   char str1[100];
   printf("enter a sentence:");
   fgets(str1, 100, stdin);
   printf("%s\n",str1);
   
   int i = 0,kongge = 0;
   do
   {
                   if(str1[i] ==' ')
                   {
                           kongge++;
                }
                i++;
   }while(str1[i] != '\0');
   
   
   int string_num = 0;
   if(str1[0] == ' ')
   {
                   string_num = kongge;
   }
   else
   {
               string_num = kongge + 1;
        } 
   
   int j = 0,z = 0,m = 0;
   char array[string_num][1]; 
   int k = 0;
   do
   {
                   if(str1[k] !=' ')
                   {
                           *(*(array + j) + m) =  str1[k]; //将字符一个个存进二维数组,如何遇到空格,二维数组当前行存储结束,从下一行开始存储 
                           printf("str1[k] = %c ,*(*(array + j) + m) = %c,j = %d,m = %d \n",str1[k],*(*(array + j) + m),j,m);
                           m++;
                }
                else
                {
                        printf("*(array + j) = %s,j = %d,m = %d \n",array[j],j,m);
                           j++;
                           m = 0;
                }

                k++;
                
   }while(str1[k] != '\0');
   
//   printf("kong = %d \n",kongge);
//   printf(" %c",str1[2]); 
   for(z = 0; z<string_num; z++)
   {
                   printf("%s\n",array[z]);
   }
   
}
最佳答案
2020-11-4 22:48:51
因为你的35行定义二维数组的时候第二维长度不对,导致第一个字符串占用了后面字符串的位置,然后又被后面的覆盖了。
比如输入: abc de fg
那么第一个字符串一个是abc,但是你得意的第二维长度为1,所及就会挤占后面的位置,读到第二个字符串de的时候就会覆盖掉bc,再读到fg的时候,就会覆盖掉e
此外二维数组的每一行末尾你没有加'\0',那么在%s打印的时候就不会按照行打印,%s是遇到\0'才停止
帮你修改了一下,四处修改。做了注释
#include <stdio.h>

// 分割字符串。用户输入一个英文句子,你的程序将这个字符串按空格进行分割,
//返回由单词组成的二维数组
//不论是一个空格还是多个空格,你的程序都能够正确识别出单词来
int main()
{
    char str1[100];
    printf("enter a sentence:");
    fgets(str1, 100, stdin);
    printf("%s\n",str1);
    
    int i = 0,kongge = 0,len=0,maxlen=0;//第一处、加了两个变量,找最长的字符串
    do        //第二处、在这个循环中,添加了几行代码,除了找空格数以外,再找一下最长连续字符串的长度
    {
        if(str1[i] ==' ')
        {
            kongge++;
            if(len>maxlen)
                maxlen=len;
            len=0;
        }
        else
            len++;
        i++;
    }while(str1[i] != '\0');
   
   
    int string_num = 0;
    if(str1[0] == ' ')
    {
        string_num = kongge;
    }
    else
    {
        string_num = kongge + 1;
        } 
    
    int j = 0,z = 0,m = 0;
    char array[string_num][maxlen+1]; //第三处、这里的第二维是最长字符串长度+1,需要存放末尾的'\0'
    int k = 0;
    do
    {
        if(str1[k] !=' ')
        {
           *(*(array + j) + m) =  str1[k]; //第四处、将字符一个个存进二维数组,如何遇到空格,二维数组当前行存储结束,从下一行开始存储 
           printf("str1[k] = %c ,*(*(array + j) + m) = %c,j = %d,m = %d \n",str1[k],*(*(array + j) + m),j,m);
           m++;
        }
        else
        {
            *(*(array + j) + m) =  '\0';//末尾添加'\0'
            printf("*(array + j) = %s,j = %d,m = %d \n",array[j],j,m);
            j++;
            m = 0;
        }
        
        k++;
                
    }while(str1[k] != '\0');
    
    //   printf("kong = %d \n",kongge);
    //   printf(" %c",str1[2]); 
    for(z = 0; z<string_num; z++)
    {
        printf("%s\n",array[z]);
    }
    printf("%d,%d",maxlen,string_num);
    
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-11-4 22:13:28 | 显示全部楼层
看不明白你第35行是什么想法,解释一下吧,这种定义是不允许的,你解释一下,我看看能不能根据你的意思,修改一下程序
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-4 22:48:51 | 显示全部楼层    本楼为最佳答案   
因为你的35行定义二维数组的时候第二维长度不对,导致第一个字符串占用了后面字符串的位置,然后又被后面的覆盖了。
比如输入: abc de fg
那么第一个字符串一个是abc,但是你得意的第二维长度为1,所及就会挤占后面的位置,读到第二个字符串de的时候就会覆盖掉bc,再读到fg的时候,就会覆盖掉e
此外二维数组的每一行末尾你没有加'\0',那么在%s打印的时候就不会按照行打印,%s是遇到\0'才停止
帮你修改了一下,四处修改。做了注释
#include <stdio.h>

// 分割字符串。用户输入一个英文句子,你的程序将这个字符串按空格进行分割,
//返回由单词组成的二维数组
//不论是一个空格还是多个空格,你的程序都能够正确识别出单词来
int main()
{
    char str1[100];
    printf("enter a sentence:");
    fgets(str1, 100, stdin);
    printf("%s\n",str1);
    
    int i = 0,kongge = 0,len=0,maxlen=0;//第一处、加了两个变量,找最长的字符串
    do        //第二处、在这个循环中,添加了几行代码,除了找空格数以外,再找一下最长连续字符串的长度
    {
        if(str1[i] ==' ')
        {
            kongge++;
            if(len>maxlen)
                maxlen=len;
            len=0;
        }
        else
            len++;
        i++;
    }while(str1[i] != '\0');
   
   
    int string_num = 0;
    if(str1[0] == ' ')
    {
        string_num = kongge;
    }
    else
    {
        string_num = kongge + 1;
        } 
    
    int j = 0,z = 0,m = 0;
    char array[string_num][maxlen+1]; //第三处、这里的第二维是最长字符串长度+1,需要存放末尾的'\0'
    int k = 0;
    do
    {
        if(str1[k] !=' ')
        {
           *(*(array + j) + m) =  str1[k]; //第四处、将字符一个个存进二维数组,如何遇到空格,二维数组当前行存储结束,从下一行开始存储 
           printf("str1[k] = %c ,*(*(array + j) + m) = %c,j = %d,m = %d \n",str1[k],*(*(array + j) + m),j,m);
           m++;
        }
        else
        {
            *(*(array + j) + m) =  '\0';//末尾添加'\0'
            printf("*(array + j) = %s,j = %d,m = %d \n",array[j],j,m);
            j++;
            m = 0;
        }
        
        k++;
                
    }while(str1[k] != '\0');
    
    //   printf("kong = %d \n",kongge);
    //   printf(" %c",str1[2]); 
    for(z = 0; z<string_num; z++)
    {
        printf("%s\n",array[z]);
    }
    printf("%d,%d",maxlen,string_num);
    
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-12 17:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表