zoukankan      html  css  js  c++  java
  • 反转

    /// <summary>
    /// 数组全部反转
    /// </summary>
    /// <param name="array"></param>
    public static void ArrayReverse(int[] array)
    {
    if (array == null)
    {
    throw new ArgumentNullException("array", "array不能为null");
    }
    //算法1:自定义方法
    
    int[] newArray = new int[10];
    
    for (int i = 0; i < array.Length; i++)
    {
    newArray[i] = array[array.Length - 1 - i];
    }
    foreach (var i in newArray)
    {
    Console.Write(i + " ");
    }
    Console.ReadLine();
    
    //算法2:类库自带方法
    
    Array.Reverse(array);
    
    foreach (var i in array)
    {
    Console.Write(i + " ");
    }
    Console.ReadLine();
    
    //算法3:运用栈后进先出特性
    
    Stack stack = new Stack();
    
    foreach (var i in array)
    {
    stack.Push(i);
    }
    
    for (int i = 0; i < array.Length; i++)
    {
    array[i] = Convert.ToInt32(stack.Pop());
    }
    foreach (var i in array)
    {
    Console.Write(i + " ");
    }
    Console.ReadLine();
    }
    
    /// <summary>
    /// 数组局部反转
    /// </summary>
    public static void ArrayReverse(int[] array, int begin, int end)
    {
    if (array == null)
    {
    throw new ArgumentNullException("array", "array不能为null");
    }
    if (begin < 0)
    {
    throw new ArgumentOutOfRangeException("begin", "begin不能小于0");
    }
    if (end < begin)
    {
    throw new ArgumentOutOfRangeException("end不能小于begin", (Exception)null);
    }
    if (end > array.Length)
    {
    throw new ArgumentOutOfRangeException("end", "end超过array最大下标");
    }
    
    //算法1:自定义方法
    
    while (end > begin)
    {
    int temp = array[begin];
    
    array[begin] = array[end];
    
    array[end] = temp;
    
    begin++;
    
    end--;
    }
    
    foreach (var i in array)
    {
    Console.Write(i + " ");
    }
    Console.ReadLine();
    
    //算法2:类库自带方法
    
    Array.Reverse(array, begin, end);
    
    foreach (var i in array)
    {
    Console.Write(i + " ");
    }
    Console.ReadLine();
    }
    
    /// <summary>
    /// 字符串全部反转
    /// </summary>
    public static void StringReverse()
    {
    string str = "0123456789";
    
    string newStr = "";
    
    for (int i = 0; i < str.Length; i++)
    {
    newStr += str.Substring(str.Length - 1 - i, 1);
    }
    Console.WriteLine(newStr);
    
    Console.ReadLine();
    }
  • 相关阅读:
    Java 重写(Override)与重载(Overload)
    Java 继承
    Java 异常处理
    Java Scanner 类
    Java 流(Stream)、文件(File)和IO
    Java 方法
    Java 正则表达式
    Beta冲刺——代码规范、冲刺任务与计划
    Beta冲刺——凡事预则立
    Beta冲刺——问题总结博客(事后诸葛亮和组员交换事宜)
  • 原文地址:https://www.cnblogs.com/whlhaikuotiankong/p/3896417.html
Copyright © 2011-2022 走看看