| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1599 人关注过本帖
标题:一道ACM题,运行都对,提交到OJ上出错:Segmentation fault:段错误,检查是 ...
只看楼主 加入收藏
shf19961008
Rank: 1
等 级:新手上路
帖 子:13
专家分:2
注 册:2015-10-18
结帖率:33.33%
收藏
已结贴  问题点数:10 回复次数:3 
一道ACM题,运行都对,提交到OJ上出错:Segmentation fault:段错误,检查是否有数组越界
程序代码:
[local]1[/local]

#include <stdio.h>
int main()
{
    int n;
    int i,j,k;
    char t;
    int jishu=0;
    char str[2][1200]={{0}};
    int changdu;
    int pipei=0;
    scanf("%d",&n);
    for(i=0;i<n;i++)
    {
        //数组初始化
        for(j=0;j<2;j++)
        {
            for(k=0;k<1100;k++)
            {
                str[j][k]=0;
            }
        }
        if(i==0) getchar();
        //输入字符串
        j=0;
        while(scanf("%c",&t),t!=10)
        {
            str[0][j]=t;
            j++;
            changdu=j;
        }
        while(scanf("%c",&t),t!=10)
        {
            str[1][j]=t;
            j++;
        }
        //检验
        for(j=0;j<1100;j++)
        {
            for(k=0;str[0][k]==str[1][j];k++,j++)
            {
                jishu++;
                if(jishu==changdu)
                {
                    pipei=1;
                    goto out1;
                }
                if(str[1][j]==0) goto out1;
            }
            j-=jishu;
            jishu=0;
        }


        //输出
        out1:
            if(pipei==1)
            {
                printf("yes\n");
            }
            else
            {
                printf("no\n");
            }

        pipei=0;

    }
    return 0;
}



1b9c439b-710d-44de-a1e8-f272456a5134.png (133.12 KB)
图片附件: 游客没有浏览图片的权限,请 登录注册
搜索更多相关主题的帖子: color 
2015-10-18 11:26
shf19961008
Rank: 1
等 级:新手上路
帖 子:13
专家分:2
注 册:2015-10-18
收藏
得分:0 
题目意思解释下:
 就是判断上面的字符串有没有在下面出现过
第一个数字是测试的次数
2015-10-18 11:26
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9007
专家分:53942
注 册:2011-1-18
收藏
得分:10 
jishu 这玩意儿的值竟然残留到下一个循环
BTW:你还是好好写代码吧,比如
程序代码:
#include <stdio.h>
#include <string.h>

int main( void )
{
    unsigned n;
    scanf( "%u", &n );
    while( n-- )
    {
        char s[101], t[1001];
        scanf( "%s%s", s, t );

        // 判断s是否为t的字串,以下只是示例
        const char* p = strstr( t, s );

        puts( p?"yes":"no" );
    }

    return 0;
}

2015-10-19 10:04
shf19961008
Rank: 1
等 级:新手上路
帖 子:13
专家分:2
注 册:2015-10-18
收藏
得分:0 
刚开始学C,现在知道字符串重写代码就过了。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(void)
{
    int n;
    int i,j,k;
    char s[101];
    char t[1001];
    int pipei;
    int lens,lent;
    int cnt;
    scanf("%d",&n);
    for(i=0;i<n;i++)
 {
  memset(s,0,sizeof(char)*101);
  memset(t,0,sizeof(char)*1001);
  pipei=0;
  scanf("%100s",s);
  scanf("%1000s",t);
  lens=(int)strlen(s);
  lent=(int)strlen(t);
  for(j=0;j<=lent-lens;j++)
  {
   if(t[j]==s[0])
   {
    cnt=0;
    for(k=0;k<lens;k++)
    {
     if(t[j+k]==s[0+k])
     {
      cnt++;
     }
     if(cnt==lens)
     {
      pipei=1;
      goto out;
     }
    }
   }
  }

  out:
   if(pipei==1)
   {
    printf("yes\n");
   }
   else
   {
    printf("no\n");
   }

 }
    return 0;
}

2015-10-27 20:47
快速回复:一道ACM题,运行都对,提交到OJ上出错:Segmentation fault:段错误,检 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016155 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved