//这里说的是一个指针,指向算法的应用

//直接排序

//每个排序算法是指针指向的每个元件的特性的方便的交流

//这里的基本思想是,处理的记录的排序n - 1第二选择。

//第i次操作选择i大(小)的记录放在第i个(或者n - i - 1 个)位置上。

//即每次都将一个记录放在它终于的位置上,

//这就是所谓的“各回各家”

#include <iostream>

#include <cstdio>

using namespace std;

void SelectSort(int *Array, int n)

{

int i, j, m, a;

//从无序的序列中找到最小值的位置

for(i = 0; i < n - 1; i++)

{

m = 1;

for(j = i + 1; j < n; ++j)

{

if(*(Array + j) < *(Array + m))

m = j;

}

/*

*记录当前最小值的位置

* */





if(m != 1)

{

a = *(Array + m);

*(Array + m) = *(Array + 1);

*(Array + i) = a;

}

}





}













int main()

{

int i  = 0;

int Array[10] = {12, 2, 37, 67, 90, 1, 78, 67, 2, 32};

printf("待排序的数组为:\n");

for(i = 0; i < 10; ++i)

{

printf("%d\t", *(Array + i));

}

SelectSort(Array, 10);

printf("\n直接排序后的结果为:\n");

for(int j = 0; j <10; ++j)

{

printf("%d ", *(Array + j));

}

printf("\n");

return 0;

}





//查找,当中涉及指针的偏移

//查找分为顺序查找

//折半查找

//儿茶查找

//分块查找

//这里举的样例是二分查找

#include <iostream>

#include <cstdio>

using namespace std;

int BinarySearch(int * Array, int n, int x)

{

int low, high, middle;

low = 0, high = n - 1;

while(low <= high)

{

middle = (low + high)/2;

if(*(Array + middle) == x)

return 1;

else

{

if(*(Array + middle) >= x)

{

high = middle - 1;

}

if(*(Array + middle) <=x)

{

low = middle + 1;

}

}



}





}













int main()

{

int Array[10] = {2, 4, 5, 13, 15, 20, 30, 35, 40, 50};

int x1, x2;

x1 = 20;

x2 = 33;

if(BinarySearch(Array, 10, x1))

printf("已经找到%d\n", x1);

else

printf("未找到%d\n", x1);

if(BinarySearch(Array, 10, x2))

printf("已经找到%d\n", x2);

else

printf("未找到%d\n", x2);

return 0;

}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

C编程的指针涛 ---第九笔记的更多相关文章

  1. C编程的指针涛 ---第十笔记

    //指针实例搜索算法 //迷宫算法 //搜索是最长的使用深度优先搜索和广度优先搜索 //作为名称作为一个深度优先搜索,每路一直在寻找到底. //为了防止想法,这样的数据结构 //使得每次找到思路的时候 ...

  2. 《Java并发编程的艺术》读书笔记:二、Java并发机制的底层实现原理

    二.Java并发机制底层实现原理 这里是我的<Java并发编程的艺术>读书笔记的第二篇,对前文有兴趣的朋友可以去这里看第一篇:一.并发编程的目的与挑战 有兴趣讨论的朋友可以给我留言! 1. ...

  3. Python编程从入门到实践笔记——异常和存储数据

    Python编程从入门到实践笔记——异常和存储数据 #coding=gbk #Python编程从入门到实践笔记——异常和存储数据 #10.3异常 #Python使用被称为异常的特殊对象来管理程序执行期 ...

  4. Python编程从入门到实践笔记——文件

    Python编程从入门到实践笔记——文件 #coding=gbk #Python编程从入门到实践笔记——文件 #10.1从文件中读取数据 #1.读取整个文件 file_name = 'pi_digit ...

  5. Python编程从入门到实践笔记——类

    Python编程从入门到实践笔记——类 #coding=gbk #Python编程从入门到实践笔记——类 #9.1创建和使用类 #1.创建Dog类 class Dog():#类名首字母大写 " ...

  6. Python编程从入门到实践笔记——函数

    Python编程从入门到实践笔记——函数 #coding=gbk #Python编程从入门到实践笔记——函数 #8.1定义函数 def 函数名(形参): # [缩进]注释+函数体 #1.向函数传递信息 ...

  7. Python编程从入门到实践笔记——用户输入和while循环

    Python编程从入门到实践笔记——用户输入和while循环 #coding=utf-8 #函数input()让程序暂停运行,等待用户输入一些文本.得到用户的输入以后将其存储在一个变量中,方便后续使用 ...

  8. Python编程从入门到实践笔记——字典

    Python编程从入门到实践笔记——字典 #coding=utf-8 #字典--放在{}中的键值对:跟json很像 #键和值之间用:分隔:键值对之间用,分隔 alien_0 = {'color':'g ...

  9. Python编程从入门到实践笔记——if语句

    Python编程从入门到实践笔记——if语句 #coding=utf-8 cars=['bwm','audi','toyota','subaru','maserati'] bicycles = [&q ...

随机推荐

  1. Flynn初步:基于Docker的PaaS台

    Flynn它是一个开源PaaS台,无论要部署的应用程序,你可以建立自己的主动性Docker容器集群的实现,能特性与组件设计大量參考了传统的PaaS平台Heroku.本文旨在从使用动机.基本对象.层次架 ...

  2. ADN中国队参加微软Kinect他赢得了全国比赛三等奖,我们的创意项目与团队Kinect于Naviswork虚拟之旅

    以下是我的英语写了一个简短的总结,直接贴出来. 让我们知道我们在这参加Hackathon That's an exciting Hackathon for me and also China team ...

  3. Android开发学习总结——Android开发的一些相关概念(转)

    一.什么是3G.4G 1995年问世的第一代模拟制式手机(1G)只能进行语音通话. 1996到1997年出现的第二代GSM.CDMA等数字制式手机(2G)便增加了接收数据的功能 Ÿ 3G指的是第三代移 ...

  4. QlikView一年计算,以最新的销售数据

    总销量的新财年后年初今天是非常需要的学生经常会遇到,有两种思路: 1. 能Load当数据是生成一个称为场YTDFlag.这是本财年的时刻,本场会1,除此以外,0.因此,在报告中可使用非常方便Sum(S ...

  5. Sizzle.filter [ 源代码分析 ]

    最近的研究已Sizzle选择,对于原理中我们也不得不佩服! Sizzle中间filter办法.主要负责元素表达式过滤块的集合,在内部的方法调用Sizzle.selector.fitler滤波操作的操作 ...

  6. 如何获得 oracle RAC 11g asm spfile S档

     方法一: [root@vmrac1 ~]# su - grid [grid@vmrac1 ~]$ sqlplus / as sysasm SQL*Plus: Release 11.2.0.3.0 ...

  7. 移动开发 Native APP、Hybrid APP和Web APP介绍

    高速区分定义: Native App 以基于智能手机本地操作系统如IOS.Android.WP并使用原生程式(SDK)编写执行的须要用户安装使用的第三方应用程序; Web APP 以HTML+JS+C ...

  8. Boost.Asio c++ 网络编程翻译(26)

    Boost.Asio-其他特性 这章我们讲了解一些Boost.Asio不那么为人所知的特性.标准的stream和streambuf对象有时候会更难用一些,但正如你所见.它们也有它们的益处.最后,你会看 ...

  9. 编程算法 - 圆圈中最后剩下的数字(循环链表) 代码(C++)

    圆圈中最后剩下的数字(循环链表) 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 0,1...,n-1这n个数字排成一个圆圈, 从数字0開始 ...

  10. hdu 5076 最小割灵活运用

    这意味着更复杂的问题,关键的事实被抽象出来:每个点,能够赋予既有的值(挑两个一.需要选择,设定ai,bi). 寻找所有和最大.有条件:如果两个点同时满足: 1,:二进制只是有一个不同之处.  2:中的 ...