易截截图软件、单文件、免安装、纯绿色、仅160KB

直接选择排序 C代码

void StraightSelectionSort(int array[], unsigned int n)
{
/*
注:关键字值类型为int,数组的索引是从0开始
1. 初始状态无序区为array【0, n - 1】,有序区为空。
2. 第1趟排序从array【0, n - 1】中找到下标为k的关键字最小值,把array【k】和
array【0】交换。现在无序区为array【1, n - 1】, 有序区为array【0, 0】。
第2趟排序...
第3趟排序...
...
3. 第i趟排序(1 <= i <= n - 1),从array【i, n - 1】中找到下标为j的关键字最小值,把
array【j】和array【i - 1】交换,如果i == n - 1,则排序结束,否则继续3步骤。
*/
/* 总共需要n - 1次排序,从1到n - 1 */
for (int i = 1; i <= n - 1; i++)
{
/* k值从0到n - 2, 最后一个记录关键字值必定是最大的 */
int k = i - 1;
int swap = 0;
/* 这个for循环找到第i趟排序中无序区关键字值最小记录的下标 */
for (int j = i; j < n; j++)
{
if (array[j] < array[k])
{
k = j;
}
}
/* 如果数组中紧接有序区的无序区的第一个记录就是无序区中关键字值最小的,则不用交换 */
if (k != (i - 1))
{
swap = array[i - 1];
array[i - 1] = array[k];
array[k] = swap;
}
}
/*
算法分析
1. 关键字比较次数。
无论记录的初始状态,比较次数都是1 + 2 + 3 + 4 + ... + (n - 1) = n * (n -1) / 2;
2. 记录移动次数。
最好情况下0次, 正序, 最坏情况下3 * (n - 1)次, 反序。
那么直接选择排序的时间复杂度就是:O(n * n)。
3. 直接选择排序是一个就地排序。辅助空间O(1)。
非就地排序一般要求的辅助空间为O(n)。
4. 直接选择排序不稳定的。
反例
下标:【1 2 3】
关键字值:2 2 1
进过直接选择排序第一个2和第二个2相对位置发生了改变。
*/
}


相关文档:

c标准库函数

本文包括大部分C标准库函数,但没有列出一些用途有限的函数以及某些可以简单的从其他函数合成的函数,也没有包含多字节和本地化函数。
标准库中的各个函数、类型以及宏分别在以下标准头文件中说明:
<assert.h> <float.h> <math.h> <stdarg.h> <stdlib.h>
<ctype.h> <limits.h& ......

c头文件最后要加一个空行,知道为什么嘛?

 以前学生时代的时候就有遇到过这个问题,不过没去深究;
现在也是老问题,其实很简单,就是为了防止#include两个头文件的时候,把第一个头文件的最后一行和 第二个头文件的第一行拼接成一行;呵呵,其实很多问题都很简单,而且很隐蔽,只是我们很多时候没去注意! ......

C函数返回结构体在汇编下的实现

原文链接:http://blog.csdn.net/sytstarac/archive/2009/08/05/4411519.aspx
编译器:vc++6.0(因为此种实现依赖编译器处理)
此处只简要叙述一下机制。并附部分关键指令序列。
准备:
1,关于EBP:称做栈基址指针。为什么这样说呢?我们先来看看函数调用的过程:
参数从右到左压栈。
call指令执行,该指令将导致EIP压 ......

C/C++程序员两年历程 (1)

  不知不觉已经工作两年了,辞去了原来的工作,又跑回了我上学的地方。今天跑去一家室友介绍的公司面试。问得问题挺简单,但我答的却真不怎么地啊。回来又研究了一下,发现这些问题我应该都理解啊,怎么到别人问起的时候就全忘了一般呢。想想了发现还是学的不到位。不禁又想起了这么多年来,我都学到了什么东西呢。
& ......

Linux c的popen()

进程I/O函数,与pclose函数一起使用。
表头文件
  #include <stdio.h>
函数定义
  FILE * popen
( const char * command
, const char * type
);
  int pclose
( FILE * stream
);
函数说明
  
popen() 函数通过创建一个管道,调用 fork 产生一个子进程,执行一个 shell 以运行命令来开启一 ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号