| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
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;
 
 - }
 
  复制代码 
- 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;
 
 - }
 
  复制代码 
 
 
 |   
 
 
 
 |