温故而知新,算法在我心

2009.9.1号添加快速排序:
//快速排序
//一:你可以随机找一个基点,然后和第一个数字交换
//二:left表示把指针指向第二个数字和right表示指针指向最后一个数字
//三:left向右移动,找到大于基点的(也就是第一个)就停止移动,right向左移动找到小于基点停止移动,left和right交换数字
//四:当left和right 交叉时,把right的值和基点交换,
//当right和left指向一个数字时,交换,排序完成
//当right和left分别指向第一个和最后一个时,就改为基点的一个数字为基点
//50 65 30 43 76 80 18 50
//第一次:18 50 30 42 50 80 76 65
//第二次:18 30 43 50 50 80 76 65
//第三次:18 30 43 50 50 65 76 80 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication1
ExpandedBlockStart.gifContractedBlock.gif
{
    
class Program
ExpandedSubBlockStart.gifContractedSubBlock.gif    
{
        
static void Main(string[] args)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
ExpandedSubBlockStart.gifContractedSubBlock.gif            
int[] array = new int[] 341592768 };
            Sort(array, 
0, array.Length - 1);

            
foreach (int a in array)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                Console.Write(a);
                Console.Write(
"");
            }

            Console.Read();
        }


        
static void Sort(int[] array, int min, int max)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            
if (min >= max)
                
return;

            
int minTemp = min;
            
int maxTemp = max;

            
int middle = min;

            
int temp;

            
while (min < max)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
{
                
while (array[max] > array[middle])
                    max
--;

                temp 
= array[max];
                array[max] 
= array[middle];
                array[middle] 
= temp;
                middle 
= max;

                
while (array[min] < array[middle])
                    min
++;

                temp 
= array[min];
                array[min] 
= array[middle];
                array[middle] 
= temp;
                middle 
= min;
            }


            Sort(array, minTemp, middle 
- 1);
            Sort(array, middle 
+ 1, maxTemp);
        }

    }

}



2008-3-8-今日又去面试了,碰到一题,回来仔细写了下,不知道是不是这样效率最好:
ggg.jpg

2008-3-7-最近又开始面试了,由于长期做NET应用,导致基础算法不清,错失很多良机,故回家补习,列出几例,以便面试临时必备:
aaa.jpg
如Combind(new int[]{1,3,5}, new int[]{2,4},c)则得到,1,2,3,4,5

ccc.jpg
如a,b,c,则Permute(0)则得到abc, acb, bac,.......所有组合

ddd.jpg

eee.jpg

fff.jpg

猫叫,主人醒来,老鼠逃
bbb.jpg

转载于:https://www.cnblogs.com/guozili/archive/2008/03/07/1095101.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值