zoukankan      html  css  js  c++  java
  • 反转字符串

      反转字符串是我们经常会遇到的一种面试题,Exp: 字符串 Hello 输出位 olleH

      FUN1:看到要求的第一反应差不多是循环存储字节后倒叙输出。代码如下

    public static string StrReverseWithArray(string str)
            {
                if (string.IsNullOrEmpty(str)) return str;
                int length = str.Length;
                char[] array = str.ToCharArray();
                for (int i = 0; i < length; i++)
                {
                    array[i] = str[length - 1 - i];
                }
                return new string(array);
            }

      FUN2:分析下 input顺序:H-e-l-l-o outPut顺序是 o-l-l-e-H;实际上满足了先进先出的顺序,这和栈的特性相同,所以可以定义栈 对栈进行压栈 出栈的操作 代码如下

    public static String StrReverseWithStack(String str)
            {
                if (string.IsNullOrEmpty(str)) return str;
                var stringStack = new Stack<char>();
                char[] array = str.ToCharArray();
                foreach (char t in array)
                {
                    stringStack.Push(t);
                }
                int length = str.Length;
                for (int i = 0; i < length; i++)
                {
                    array[i] = stringStack.Pop();
                }
                return new string(array);
            }

      FUN3:反转字符串实际上也是逆序遍历字符串 输出

     public static string StrReverseWithReverseLoop(String str)
            {
                if (string.IsNullOrEmpty(str)) return str;
                var sb = new StringBuilder();
                for (int i = str.Length - 1; i >= 0; i--)
                {
                    sb.Append(str[i]);
                }
                return sb.ToString();
            }

      FUN4:反转字符串也就是从收尾两端依次交换到中间位置的过程,我们可以用递归的方法来实现 只需要 做到

    • 找出递归结束的临界条件
    • 对针对于临界条件的不同的值做出不同的处理

    代码实现  

        public static String StrReverseWithRecursive(String str)
            {
                if (string.IsNullOrEmpty(str)) return str;
                int length = str.Length;
                if (length == 1)
                {
                    return str;
                }
                else
                {
                    return StrReverseWithRecursive(str.Substring(1)) + str[0];
                }
            }

    OK

      

  • 相关阅读:
    C# 如何在PDF文档中创建表格
    C# 如何创建Excel多级分组
    C# 添加、修改以及删除Excel迷你图表的方法
    C# 创建EXCEL图表并保存为图片
    【BZOJ5287】[HNOI2018]毒瘤(动态规划,容斥)
    【BZOJ5250】[九省联考2018]秘密袭击(动态规划)
    【BZOJ5213】[ZJOI2018]迷宫(神仙题)
    CodeForces Global Round 1
    【BZOJ5212】[ZJOI2018]历史(Link-Cut Tree)
    【BZOJ5211】[ZJOI2018]线图(树哈希,动态规划)
  • 原文地址:https://www.cnblogs.com/a164266729/p/5610948.html
Copyright © 2011-2022 走看看