快速排序发 继承构造方法的调用顺序

写一个读取数字的类 实现输入小于max参数的数,实现输入介于min和max之间的数字,实现输入一个整数,使用指定默认参数代替了方法重载。

代码:

class JKConsole
    {
        public static int ReadInt(int max = int.MaxValue, int min = int.MinValue)
        {
            if (max!=int.MaxValue && min==int.MinValue)
            {
                min = 0;
            }
            if (max!=int.MaxValue && min!=int.MinValue)
            {
                if (max>min)
                {
                    int temp = max;
                    max = min;
                    min = temp;
                }
            }
            int num=0;
            do 
            {          
                Console.WriteLine("请输入一个数字");
                string str = Console.ReadLine();
                if (int.TryParse(str,out  num))
                {
                    if (num>min &&num <max)
                    {
                        return num;
                    }
                    else
                    {
                        Console.Write("输入的数字不在{0}-{1}范围内", min, max);
                        continue;
                    }
                }
                Console.Write("输入的格式有误");            
            } while (true);
        }
    }
View Code
class Program
    {
        static void Main(string[] args)
        {
            int num = JKLibrary.NumberHelper.JKConsole.ReadInt(0, 100);
            int num1 = JKLibrary.NumberHelper.JKConsole.ReadInt(100);
            int num2 = JKLibrary.NumberHelper.JKConsole.ReadInt();
        }
    }
View Code

新增知识点:命名空间可以嵌套

namespace n1
{
    namespace n2
    {
        namespace n3
        {
            class c
            {

            }
        }
    }
//等价于
namespace n1.n2.n3
{
    class c
    {

    }
View Code

快速排序法

class Program
    {
        static void Main(string[] args)
        {
            int[] array = { 1,3,4,7,2,7,9,0,-13};
            Sort(array, 0, array.Length - 1);
            foreach (var item in array)
            {
                Console.Write(item + " ");
            }
            Console.ReadKey();
            
        }
        static int GetIndex(int[] array, int leftIndex, int rightIndex)
        {
            int luler = array[leftIndex];
            while (leftIndex < rightIndex)
            {
                while (leftIndex<rightIndex &&array[rightIndex]>luler)
                {
                    rightIndex--;
                }
                if (leftIndex<rightIndex)
                {
                    array[leftIndex] = array[rightIndex];
                    leftIndex++;
                }
                 while(leftIndex<rightIndex && array[leftIndex]<luler){
                    leftIndex++;
                 }
                 if (leftIndex<rightIndex){
                    array[rightIndex] = array[leftIndex];
                    rightIndex--;
                    }
              }
            array[leftIndex] = luler;
            return leftIndex;
        }
        static void Sort(int[] array, int left, int right)
        {
            if (left<right)
            {
                int temp = GetIndex(array, left, right);
                Sort(array,left,temp-1);
                Sort(array, temp + 1, right);
            }
        }
    }
View Code

继承,构造方法的执行顺序内等容前面博客已经记载见http://www.cnblogs.com/tobecabbage/p/3459014.html此处省略

 

 

posted @ 2014-01-20 18:16  我叫小菜  阅读(181)  评论(0编辑  收藏  举报