鱼C论坛

 找回密码
 立即注册
查看: 1401|回复: 5

[已解决]求助,根据题目要求我写的代码有错误吗?

[复制链接]
发表于 2019-1-28 11:31:24 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 NYJYA 于 2019-1-28 11:47 编辑

题目描述:
小鹏有一面镜子,可以把接触的东西变成原来的两倍。但是因为是镜子嘛,只能对称变换。假如有一个为BA的珍珠项链,字母不一样代表的颜色不一样。现在小鹏用镜子将项链复制之后,项链变成了BAAB。如果再复制一遍的话,项链就会变成BAABBAAB。因为小鹏比较贪心,一直复制,最后竟然忘记原来的项链是什么样的了,接下来就请聪明的acmer编写程序,算出最开始项链的长度吧。

输入:
第一行N表示接下来有N(N<=10)个串;之后的N行,每行是一个不超过100个大写英文字母组成的串。

输出:
输出N行,每行是项链的初始长度
我写了两种代码,但都通不过,先谢谢大家了。
第一种:没有判断是不是大写字母的
#include<stdio.h>
#include<string.h>
int main()
{
        int N,i,j,num,b[100],k=0;
        char a[11][101];
        scanf("%d",&N);
        getchar();
        for(i=0;i<N;i++)
        {
                gets(a[i]);
        }
        for(i=0;i<N;i++)
        {
                        num=1;
                for(j=1;j<strlen(a[i])/2;j++)
                {
                
                        if(a[i][k]!=a[i][j] && a[i][j]!=a[i][j-1]) num=num+1;
                }
                b[i]=num;
        }
        for(i=0;i<N;i++)
        {
                printf("%d\n",b[i]);
        }
        return 0;
}
第二种:有判断是大写字母的
#include<stdio.h>
#include<string.h>
int main()
{
        int N,n,m,i,j,num,b[100],k=0,c,d=0;
        char a[11][101];
        scanf("%d",&N);
        getchar();
        for(i=0;i<N;i++)
        {
                gets(a[i]);
        }
        for(i=0;i<N;i++)
        {
                for(j=0;j<strlen(a[i]);j++)
                {
                        if(a[i][j]>='A' && a[i][j]<='Z')
                        c=1;
                        else 
                        {
                                c=0;
                                break;        
                        }
                }        
                if(c==0) continue;
                else 
                {
                        num=1;
                        for(m=1;m<strlen(a[i])/2;m++)
                {
                
                        if(a[i][k]!=a[i][m] && a[i][m]!=a[i][m-1]) num=num+1;
                }
                        b[d]=num;d=d+1;
        }
        
        }
        for(n=0;n<d;n++)
                {
                        printf("%d\n",b[n]);
                }
        return 0;
}
最佳答案
2019-1-28 16:51:24
int OriginStringLength(char* sz)   //获取原始字符的长度 
{
    int length,i;
    for (length=0;sz[length]!='\0';++length);     //字符串总是以'\0'结尾 
        
    if (length==0) return 0;                                        //如果长度为0,原始字符串也只可能是0长度 
    while ((length & 1)==0)                                                //如果长度为奇数,则说明不需要继续分解 
    {
        for (i=0;i<length/2;++i)                                                //查看字符串是否回文 , 
            if (sz[i]!=sz[length-1-i]) goto EndWhile;   //不是回文则跳出 
        length=length>>1;                                                                //否则取前半,继续循环,直到字符串不是回文为止 
    }
        
    EndWhile:
    return length;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-1-28 14:01:27 | 显示全部楼层
        for(m=1;m<strlen(a[i])/2;m++)
                {
                
                        if(a[i][k]!=a[i][m] && a[i][m]!=a[i][m-1]) num=num+1;
                }
我没看懂这一段思路是什么,k只有在声明的时候=0,能讲一讲么
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-1-28 14:16:53 | 显示全部楼层
本帖最后由 Croper 于 2019-1-28 14:26 编辑
#include <stdio.h>

int OriginStringLength(char* sz)
{
    int length,i;
    for (length=0;sz[length]!='\0';++length);
        
    if (length==0) return 0;
    while ((length & 1)==0)
    {
        for (i=0;i<length/2;++i)
            if (sz[i]!=sz[length-1-i]) goto EndWhile;
        length=length>>1;
    }
        
    EndWhile:
    return length;
}

int main()
{
    int N,i;
    int ans[10];
    char sz[100];
    scanf("%d",&N);
    getchar();
    for (i=0;i<N;++i)
    {
        gets(sz);
        ans[i]=OriginStringLength(sz);
    }
    for (i=0;i<N;++i)
        printf("%d\n",ans[i]);
        
    return 0;
} 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-1-28 15:27:05 | 显示全部楼层


可不可以讲讲你的思路?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-1-28 16:51:24 | 显示全部楼层    本楼为最佳答案   
int OriginStringLength(char* sz)   //获取原始字符的长度 
{
    int length,i;
    for (length=0;sz[length]!='\0';++length);     //字符串总是以'\0'结尾 
        
    if (length==0) return 0;                                        //如果长度为0,原始字符串也只可能是0长度 
    while ((length & 1)==0)                                                //如果长度为奇数,则说明不需要继续分解 
    {
        for (i=0;i<length/2;++i)                                                //查看字符串是否回文 , 
            if (sz[i]!=sz[length-1-i]) goto EndWhile;   //不是回文则跳出 
        length=length>>1;                                                                //否则取前半,继续循环,直到字符串不是回文为止 
    }
        
    EndWhile:
    return length;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-1-28 22:36:21 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-17 14:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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