神鸟 发表于 2012-8-8 21:44

请大家给个思路,实在想不出了

a
……
z
aa
……
az
ba
……
bz
ca
……
zz
……
aaa
效果如图
用代码如何实现

执着的最后 发表于 2012-8-8 21:49

{:1_907:}撸猪发问题贴小心点 别被扣分了

liuyongliang 发表于 2012-8-8 21:50

没看懂是什么

kuwo911 发表于 2012-8-8 21:51

楼主要用啥语言得到啊,要说明一下下嘀

索马里的海贼 发表于 2012-8-8 21:52

class Program
    {
      private static char[] arr = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' };
      static void Main(string[] args)
      {
            string input = Console.ReadLine();
            while (input.Length > 0)
            {
                input = input.ToUpper();
                Console.WriteLine(NextLetter(input));
                input = Console.ReadLine();
            }
      }
      private static string NextLetter(string input)
      {
            char[] arr_input = input.ToCharArray();// 将输入字符转成字符数组
            // 保存结果的数组,考虑产生进位的情况,长度+1
            // 结果数组保存的不是字符,是保存字符的索引号
            int[] arr_index = new int;
            // 初始化结果数组
   for (int i = 0; i < arr_index.Length; i++)
            {
                arr_index = -1;
            }
            // 第一步:先将输入字符数组转化成字符索引号保存到结果数组
            int j = 0;
            for (int i = arr_input.Length - 1; i >= 0; i--)
            {
                arr_index = LetterIndex(arr_input);
                j++;
            }

   // 对结果数组进行+1操作, 采用26进制, +1操作后的结果数组就是 后续编号 对应的索引号
            j = 0;
            arr_index = arr_index + 1;
            while (arr_index % 26 == 0 && j < arr_input.Length)
            {
                arr_index = arr_index % 26;
                j++;
                if (arr_index == 0)
                  arr_index = arr_index + 1;
            }
   // 将字符索引号转化成对应的字符返回
            string next = "";
            for (int i = arr_index.Length - 1; i >= 0; i--)
            {
                if (arr_index >= 0)
                  next += arr].ToString();
            }
            return next;
      }
      private static int LetterIndex(char letter)
      {
            int index = 0;
            for (index = 0; index < arr.Length; index++)
            {
                if (letter == arr)
                  break;
            }
            return index;
      }
    }百度的

页: [1]
查看完整版本: 请大家给个思路,实在想不出了