| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1294 人关注过本帖
标题:回文串问题,求助。
只看楼主 加入收藏
宁缺T
Rank: 1
等 级:新手上路
帖 子:21
专家分:8
注 册:2019-9-12
结帖率:87.5%
收藏
已结贴  问题点数:20 回复次数:5 
回文串问题,求助。
题目就是回文串的问题

代码如下:
程序代码:
#include<stdio.h>
#include<string.h>
int main(){
    int i,j;
    int flag=1;
    char str[256];
    gets(str);
    j=strlen(str);
    for(i=0;i<j/2;i++){
        if(str[i]!=str[j-1-i]){
            flag=0;
        }
    }

    if(flag==1)
      printf("YES");
      else
      printf("NO");
      return 0;
   

}
代码在系统上过了,但是我输入上海自来水来自海上的时候他输出的是NO.
-----------------------------------------------
我以前写的是这个,程序报的是C2100错误讲是数组越界没明白,求助大佬指点一下

程序代码:
#include<stdio.h>
#include<string.h>
int main33(){
    int i;
    int flag=0;
    int time=0;
    char * front,back;
    char str[20]=" ";
    gets(str);
    front=str;
    back=&str[strlen(str)-1];
  
    while((*front)==(*back)&&time<strlen(str)/2){
        front++;
        back--;
        time++;
    }
    if(time==strlen(str)/2)
       flag=1;
      

    if(flag==1)
      printf("YES");
      else
      printf("NO");
      return 0;
   

}

搜索更多相关主题的帖子: str 回文 int flag strlen 
2019-12-08 21:52
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9007
专家分:53942
注 册:2011-1-18
收藏
得分:0 
一个汉字占两个char (至少占两个字节)
不知道你明白了没有
假设 汉 是 ab,那么 汉汉 就是 abab,以字节计,它当然就不是回文
2019-12-08 22:00
宁缺T
Rank: 1
等 级:新手上路
帖 子:21
专家分:8
注 册:2019-9-12
收藏
得分:0 
回复 2楼 rjsp
嗯,大体上能明白。您能帮我解释一下 while((*front)==(*back)&&time<strlen(str)/2))这句话报错的原因吗?


Stay hungry,Stay foolish.
2019-12-09 20:08
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9007
专家分:53942
注 册:2011-1-18
收藏
得分:0 
char * front,back;
……
*back
应该编译通不过吧
2019-12-09 21:57
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9007
专家分:53942
注 册:2011-1-18
收藏
得分:20 
完全按照你的逻辑,改正了代码错误
程序代码:
#include <stdio.h>
#include <string.h>

int main( void )
{
    char str[256];
   gets( str ); // 这一句我就没法改了,因为 gets 在C99中就被废弃了,在C11中连名字都删掉了

    const size_t n = strlen(str);
    size_t times = 0;
    for( const char *front=str,*back=str+n-1; *front==*back && times<n/2; ++front,--back,++times );
    puts( times==n/2 ? "YES" : "NO" );
}

2019-12-09 22:14
宁缺T
Rank: 1
等 级:新手上路
帖 子:21
专家分:8
注 册:2019-9-12
收藏
得分:0 
回复 5楼 rjsp
好的,谢谢我再看看

Stay hungry,Stay foolish.
2019-12-11 10:12
快速回复:回文串问题,求助。
数据加载中...
 
   



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

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