zoukankan      html  css  js  c++  java
  • 随机生成1024个数,用指针进行排序,并实现二分查找

    题目:随机生成1024个数,用指针进行排序,并实现二分查找,具体实现如下:

    #include<stdlib.h>
    #include<stdio.h>
    
    int SortByPtr(int * pInput, int nLen)
    {
    	if (!pInput)
    	{
    		return 0;
    	}
    	int * pCur = pInput;
    	int * pEnd = pInput + nLen;
    	int * pCur2 = NULL;
    	int * pEnd2 = pEnd;
    	int nTemp = 0;
    	for (; pCur < pEnd - 1; pCur++)
    	{
    		for (pCur2 = pEnd2-1; pCur2 > pCur; pCur2--)
    		{
    			if (*pCur2 < *(pCur2 - 1))
    			{
    				nTemp = *pCur2;
    				*pCur2 = *(pCur2 - 1);
    				*(pCur2 - 1) = nTemp;
    			}
    		}
    	}
    	return 1;
    }
    
    int BinSort(int * pInput, int nLow, int nHigh, int nKey, int * pFind)
    {
    	if (!pInput || !pFind)
    	{
    		return 0;
    	}
    
    	*pFind = 0;
    
    	if (nLow > nHigh)
    	{
    		return 1;
    	}
    
    	int nMid = (nHigh + nLow) / 2;
    
    	if (pInput[nMid] == nKey)
    	{
    		*pFind = 1;
    		return 1;
    	}
    	else if (pInput[nMid] > nKey)
    	{
    		return BinSort(pInput, nLow, nMid - 1, nKey, pFind);
    	}
    	else
    	{
    		return BinSort(pInput, nMid + 1, nHigh, nKey, pFind);
    	}
    }
    
    int BinSortPtr(int * pInput, int nLow, int nHigh, int nKey, int * pFind)
    {
    	if (!pInput || !pFind)
    	{
    		return 0;
    	}
    
    	*pFind = 0;
    
    	if (nLow > nHigh)
    	{
    		return 1;
    	}
    
    	int nMid = (nHigh + nLow) / 2;
    
    	int * pTemp = pInput + nMid;
    
    	if (*pTemp == nKey)
    	{
    		*pFind = 1;
    		return 1;
    	}
    	else if (*pTemp > nKey)
    	{
    		return BinSort(pInput, nLow, nMid - 1, nKey, pFind);
    	}
    	else
    	{
    		return BinSort(pInput, nMid + 1, nHigh, nKey, pFind);
    	}
    }
    int main()
    {
    	int data[10] = { 4, 5, 1, 3, 2, 0, 6, 7, 9, 8 };
    	int i = 0;
    	if (SortByPtr(data, 10) == 0)
    	{
    		printf("排序失败.
    ");
    	}
    	else
    	{
    		printf("排序后:
    ");
    		for (i = 0; i < 10; i++)
    		{
    			printf("%d	", data[i]);
    		}
    		printf("
    ");
    	}
    	int nFind = 0;
    	if (BinSort(data, 0, 9, 9, &nFind) == 0)
    	{
    		printf("查找失败.
    ");
    	}
    	else
    	{
    		if (nFind == 1)
    		{
    			printf("查找成功.
    ");
    		}
    		else
    		{
    			printf("查找不成功.
    ");
    		}
    	}
    	if (BinSortPtr(data, 0, 9, 9, &nFind) == 0)
    	{
    		printf("查找失败.
    ");
    	}
    	else
    	{
    		if (nFind == 1)
    		{
    			printf("查找成功.
    ");
    		}
    		else
    		{
    			printf("查找不成功.
    ");
    		}
    	}
    	system("pause");
    	return 0;
    }
    运行效果如图1所示:

    图1 运行效果

  • 相关阅读:
    MDL中捕获到损坏的页表页
    跟踪MmSt分页池使用情况
    了解NTFS压缩
    如何跟踪高CPU在用户模式应用程序-现场调试!
    如何与转储文件建立丰富多彩的关系
    Kernel Stack Overflows
    非分页池的消耗
    MBR反汇编
    LPC (Local procedure calls)(二)内核调试扩展
    LPC (Local procedure calls) (一)数据结构
  • 原文地址:https://www.cnblogs.com/new0801/p/6176905.html
Copyright © 2011-2022 走看看