C/C++ 常用排序算法整理汇总分享

(伪)冒泡排序算法:

相邻的两个元素之间,如果反序则交换数值,直到没有反序的记录为止.

#include <stdio.h>

void BubbleSort(int Array[], int ArraySize)
{
	int x, y, temporary;

	for (x = 0; x < ArraySize - 1; x++)
	{
		for (y = x + 1; y < ArraySize; y++)
		{
			if (Array[x] > Array[y])
			{
				temporary = Array[y];
				Array[y] = Array[x];
				Array[x] = temporary;
			}
		}
	}
}

int main(int argc, char* argv[])
{
	int a[10] = { 2, 5, 6, 8, 2, 3, 9, 1, 8, 0 };

	BubbleSort(a, 10);

	for (int i = 0; i < 10; i++)
	{
		printf("%d ", a[i]);
	}

	system("pause");
	return 0;
}

(真)冒泡排序算法:

正宗的冒泡排序就是从下往上两两比较,所以看上去就像是泡泡向上冒一样.

#include <stdio.h>

void BubbleSort(int Array[], int ArraySize)
{
	int x, y, temporary;

	for (x = 0; x < ArraySize - 1; x++)
	{
		for (y = ArraySize - 1; y > x; y--)
		{
			if (Array[y-1] > Array[y])
			{
				temporary = Array[y-1];
				Array[y-1] = Array[y];
				Array[y] = temporary;
			}
		}
	}
}

int main(int argc, char* argv[])
{
	int a[10] = { 2, 5, 6, 8, 2, 3, 9, 1, 8, 0 };

	BubbleSort(a, 10);

	for (int i = 0; i < 10; i++)
	{
		printf("%d ", a[i]);
	}

	system("pause");
	return 0;
}

选择排序算法:

该算法通过Array-x次关键字比较,从Array-x+1个记录中选出关键字最小的记录,并和第x个记录交换.

#include <stdio.h>

void SelectSort(int Array[], int ArraySize)
{
	int x, y, minimum, temporary;

	for (x = 0; x < ArraySize - 1; x++)
	{
		minimum = x;   // 假设x是最小的数
		for (y = x + 1; y < ArraySize; y++)
		{  // 将假设中的最小值进行比对
			if (Array[y] < Array[minimum])
				minimum = y;
		}
		if (minimum != x)
		{ // 循环结束后进行交换
			temporary = Array[minimum];
			Array[minimum] = Array[x];
			Array[x] = temporary;
		}
	}
}

int main(int argc, char* argv[])
{
	int a[10] = { 2, 5, 6, 8, 2, 3, 9, 1, 8, 0 };

	SelectSort(a, 10);

	for (int i = 0; i < 10; i++)
	{
		printf("%d ", a[i]);
	}

	system("pause");
	return 0;
}

直接插入排序:

该算法将一个记录插入到已经排好序的有序表中,从而得到一个新的,记录数增加1的有序表.

#include <stdio.h>

void InsertSort(int Array[], int ArraySize)
{
	int x, y, temporary;

	for (x = 1; x < ArraySize; x++)
	{
		if (Array[x] < Array[x - 1])
		{
			temporary = Array[x];  // 把小的元素放入temp
			for (y = x - 1; Array[y] > temporary; y--)
			{
				Array[y + 1] = Array[y];
			}
			Array[y + 1] = temporary;
		}
	}
}

int main(int argc, char* argv[])
{
	int a[10] = { 2, 5, 6, 8, 2, 3, 9, 1, 8, 0 };

	InsertSort(a, 10);

	for (int i = 0; i < 10; i++)
	{
		printf("%d ", a[i]);
	}

	system("pause");
	return 0;
}

(分组)希尔排序:

在直接插入排序进行升级,把记录进行分组,分割成若干个子序列,把每一个子序列分别进行插入排序.

#include <stdio.h>

void ShellSort(int Array[], int ArraySize)
{
	int x, y, temporary;
	int interval = ArraySize;   // 设置排序间隔

	do
	{
		interval = interval / 3 + 1;
		for (x = interval; x < ArraySize; x++)
		{
			if (Array[x] < Array[x - interval])
			{
				temporary = Array[x];  // 把小的元素放入temp
				for (y = x - interval; Array[y] > temporary; y -= interval)
				{
					Array[y + interval] = Array[y];
				}
				Array[y + interval] = temporary;
			}
		}
	} while (interval > 1);
}

int main(int argc, char* argv[])
{
	int a[10] = { 2, 5, 6, 8, 2, 3, 9, 1, 8, 0 };

	ShellSort(a, 10);

	for (int i = 0; i < 10; i++)
	{
		printf("%d ", a[i]);
	}

	system("pause");
	return 0;
}

归并排序算法:

将数组拆分成两部分,然后将每部分再次拆成两部分,直到无法拆了为止,然后两两比较,最后在归并到一起.

#include <stdio.h>
#define MAXSIZE 10

// 实现归并,并把最后的结果存放到list1里面
void merging(int *list1,int list1_size,int *list2,int list2_size)
{
	int list1_sub = 0, list2_sub = 0, k = 0;
	int temporary[MAXSIZE];

	while (list1_sub < list1_size && list2_sub < list2_size)
	{
		if (list1[list1_sub] < list2[list2_sub])
			temporary[k++] = list1[list1_sub++];
		else
			temporary[k++] = list2[list2_sub++];
	}
	while (list1_sub < list1_size)
		temporary[k++] = list1[list1_sub++];
	while (list2_sub < list2_size)
		temporary[k++] = list2[list2_sub++];

	// 最后将归并后的结果存入到list1变量中
	for (int m = 0; m < (list1_size + list2_size); m++)
		list1[m] = temporary[m];
}

// 拆分数组,拆分以后传入merging函数实现归并
void MergeSort(int Array[], int ArraySize)
{   // 如果大于1则终止拆解数组
	if (ArraySize > 1)
	{
		int *list1 = Array;                // 左边部分
		int list1_size = ArraySize / 2;    // 左边的尺寸,每次是n/2一半

		int *list2 = Array + ArraySize / 2;       // 右半部分,就是左半部分的地址加上右半部分的尺寸
		int list2_size = ArraySize - list1_size;  // 右半部分尺寸

		MergeSort(list1, list1_size);   // 递归拆解数组1
		MergeSort(list2, list2_size);   // 递归拆解数组2
		merging(list1, list1_size, list2, list2_size);  // 归并
	}
}

int main(int argc, char* argv[])
{
	int a[10] = { 2, 5, 6, 8, 2, 3, 9, 1, 8, 0 };

	MergeSort(a, 10);
	for (int i = 0; i < 10; i++)
		printf("%d ", a[i]);

	system("pause");
	return 0;
}

迭代归并排序:

代码指针存在问题.

#include <stdio.h>
#include <stdlib.h>

void MergeSort(int k[], int n)
{
	int i, left_min, left_max, right_min, right_max;
	// 申请临时空间
	int *temp = (int *)malloc(n * sizeof(int));

	for (i = 1; i < n; i *= 2)  // i => 步长,每次对比两个元素
	{
		for (left_min = 0; left_min < n - i; left_min = right_max)
		{
			right_min = left_max = left_min + i;
			right_max = left_max + i;
			if (right_max > n) // 有时数组无法整除,我们来处理一下
			{
				right_max = n;
			}
			int next = 0;
			while (left_min < left_max && right_min < right_max)
			{
				if (k[left_min] < k[right_min])
				{
					temp[next++] = k[left_min];
				}
				else
				{
					temp[next++] = k[right_min];
				}
			}

			while (left_min < left_max)
			{
				k[--right_min] = k[--left_min];
			}
			while (next >0)
			{
				k[--right_min] = temp[--next];
			}
		}
	}
}

int main(int argc, char* argv[])
{
	int a[10] = { 2, 5, 6, 8, 2, 3, 9, 1, 8, 0 };

	MergeSort(a, 10);
	for (int i = 0; i < 10; i++)
		printf("%d ", a[i]);

	system("pause");
	return 0;
}

迭代归并排序2:

代码指针存在问题.

#include <stdio.h>
#include <stdlib.h>

// 定义链表节点类型
struct LinkNode
{
	int data;
	struct LinkNode *next;
};

struct LinkNode *init_link()
{  // 创建一个头结点,头结点不需要添加任何数据
	struct LinkNode *header = malloc(sizeof(struct LinkNode));
	header->data = 0;
	header->next = NULL;

	struct LinkNode *p_end = header;    // 创建一个尾指针

	int val = -1;
	while (1)
	{
		scanf("%d", &val);  // 输入插入的数据
		if (val == -1)      // 如果输入-1说明输入结束了
			break;

		// 先创建新节点
		struct LinkNode *newnode = malloc(sizeof(struct LinkNode));
		newnode->data = val;
		newnode->next = NULL;

		// 将节点插入到链表中
		p_end->next = newnode;
		// 更新尾部指针指向
		p_end = newnode;
	}
	return header;
}

// 遍历链表
int foreach_link(struct LinkNode *header)
{
	if (NULL == header || header->next == NULL)
		return 0;

	while (header->next != NULL)
	{
		printf("%d \n", header->data);
		header = header->next;
	}
	return 1;
}

// 在header节点中oldval插入数据
void insert_link(struct LinkNode *header,int oldval,int newval)
{
	struct LinkNode *pPrev = header;
	struct LinkNode *Current = pPrev->next;

	if (NULL == header)
		return;

	while (Current != NULL)
	{
		if (Current->data == oldval)
			break;

		pPrev = Current;
		Current = Current->next;
	}
	// 如果值不存在则默认插入到尾部
	//if (Current == NULL)
	//	return;

	// 创建新节点

	struct LinkNode *newnode = malloc(sizeof(struct LinkNode));
	newnode->data = newval;
	newnode->next = NULL;

	// 新节点插入到链表中
	newnode->next = Current;
	pPrev->next = newnode;
}

// 清空链表
void clear_link(struct LinkNode *header)
{
	// 辅助指针
	struct LinkNode *Current = header->next;

	while (Current != NULL)
	{
		// 保存下一个节点地址
		struct LinkNode *pNext = Current->next;
		printf("清空数据: %d \n", Current->data);
		free(Current);
		Current = pNext;
	}
	header->next = NULL;
}

// 删除值为val的节点
int remove_link(struct LinkNode *header, int delValue)
{
	if (NULL == header)
		return;

	// 设置两个指针,指向头结点和尾结点
	struct LinkNode *pPrev = header;
	struct LinkNode *Current = pPrev->next;

	while (Current != NULL)
	{
		if (Current->data == delValue)
		{
			// 删除节点的过程
			pPrev->next = Current->next;
			free(Current);
			Current = NULL;
		}
	}

	// 移动两个辅助指针
	pPrev = Current;
	Current = Current->next;
}

// 销毁链表
void destroy_link(struct LinkNode *header)
{
	if (NULL == header)
		return;

	struct LinkNode *Curent = header;
	while (Curent != NULL)
	{
		// 先来保存一下下一个节点地址
		struct LinkNode *pNext = Curent->next;
		free(Curent);
		// 指针向后移动
		Curent = pNext;
	}
}

// 反响排序
void reverse_link(struct LinkNode *header)
{
	if (NULL == header)
		return;

	struct LinkNode *pPrev = NULL;
	struct LinkNode *Current = header->next;
	struct LinkNode * pNext = NULL;

	while (Current != NULL)
	{
		pNext = Current->next;
		Current->next = pPrev;
		pPrev = Current;
		Current = pNext;
	}
	header->next = pPrev;
}

int main(int argc, char* argv[])
{

	struct LinkNode * header = init_link();

	reverse_link(header);
	foreach_link(header);

	clear_link(header);
	system("pause");
	return 0;
}

以下代码来源于网络

技巧01:冒泡排序

#include <stdio.h>
int main(int argc, char *argv[])
{
  int i,j,t,a[11];
  printf ("please input 10 numbers:\n");
  for(i=1;i<11;i++)
    scanf("%d",&a[i]);
  for(i=1;i<10;i++)        //i代表比较的趟数
    for(j=1;j<11-i;j++)    //j代表每趟两两比较的次数
      if (a[j]>a[j+1])
	{
	  t=a[j];
	  a[j]=a[j+1];
	  a[j+1]=t;
	}
  printf ("the sorted numbers:\n");
  for(i=1;i<=10;i++)
    printf ("%5d",a[i]);
  return 0;
}

技巧02:选择排序

#include <stdio.h>
int main(int argc, char *argv[])
{
  int i,j,t,a[11];
  printf ("please input 10 numbers:\n");
  for(i=1;i<11;i++)
    scanf("%d",&a[i]);
  for(i=1;i<=9;i++)
    for(j=i+1;j<=10;j++)
      if (a[i]>a[j])
	{
	  t=a[i];
	  a[i]=a[j];
	  a[j]=t;
	}
  printf ("the sorted numbers:\n");
  for(i=1;i<=10;i++)
    printf ("%5d",a[i]);
  return 0;
}

技巧03:直接插入排序

#include <stdio.h>
 void insort(int s[],int n)
 {            //数组的下标从2开始,0做监视哨,1 一个数据无可比性
   int i,j;
   for (i=2; i<=n; i++)
     {
       s[0]=s[i];
       j=i-1;
       while(s[0]<s[j])
	 {
	   s[j+1]=s[j];
	   j--;
	 }
       s[j+1]=s[0];
     }
 }
int main(int argc, char *argv[])
{
  int a[11],i;
  printf ("please input number:\n");
  for(i=1;i<=10;i++)
    scanf("%d",&a[i]);
  printf ("the original order:\n");
  for(i=1;i<11;i++)
    printf ("%5d",a[i]);
  insort(a,10);
  printf ("\nthe sorted numbers:\n");
  for(i=1;i<11;i++)
    printf ("%5d",a[i]);
  return 0;
}

技巧04:归并排序

#include <stdio.h>
void merge(int r[],int s[],int x1,int x2,int x3)
{              //实现一次归并排序函数
  int i,j,k;
  i=x1;        //第一部分的开始位置
  j=x2+1;      //第二部分的开始位置
  k=x1;
  while((i<=x2)&&(j<=x3))
    //当i和j都在两个要合并的部分中
    if (r[i]<=r[j])   //筛选两部分中较小的元素放到数组s中
      {
	s[k]=r[j];
	i++;
	k++;
      }
    else
      {
	s[k]=r[j];
	j++;
	k++;
      }
  while(i<=x2)        //将x1,x2范围内的未比较的数顺次加到数组r中
    s[k++]=r[i++];
  while(j<=x3)        //将x2,x3范围内的未比较的数顺次加到数组r中
    s[k++]=r[j++];
}
void merge_sort(int r[],int s[],int m,int n)
{
  int p;
  int t[20];
  if(m==n)
    s[m]=r[m];
  else
    {
      p=(m+n)/2;
      merge_sort(r,t,m,p);
      //递归调用merge_sort函数将r[m],r[p]归并成有序的t[m],t[p]
      merge_sort(r,t,p+1,n);
      //递归调用merge_sort函数将r[p+1],r[n]归并成有序的t[p+1],t[n]
      merge(t,s,m,p,n);
      //调有函数将前两部分归并到s[m],s[n]
    }
}
main()
{
  int a[11];
  int i;
  printf ("please input 10 numbers:\n");
  for(i=1;i<=10;i++)        //从键盘中输入10个数
    scanf("%d",&a[i]);
  merge_sort(a,a,1,10);     //调用merge_sort函数进行归并排序
  printf ("the sorted numbers:\n");
  for(i=1;i<=10;i++)
    printf ("%5d",a[i]);    //将排序后的结构输出
  return 0;
}

技巧05:希尔排序(插入排序的改进)

#include <stdio.h>
void shsort(int s[],int n)
{
  int i,j,d;
  d=n/2;            //确定固定增量值
  while(d>=1)
    {
      for (i=d+1; i<=n; i++)  //数组下标从d+1开始进行直接插入排序
	{
	  s[0]=s[i];          //设置监视哨
	  j=i-d;              //确定要进行比较的元素的最右边位置
	  while((j>0)&&(s[0]<s[j]))
	    {
	      s[j+d]=s[j];    //数据右移
	      j=j-d;          //向左移d个位置
	    }
	  s[j+d]=s[0];        //在确定的位置插入s[i]
	}
      d=d/2;                  //增量变为原来的一半
    }
}
int main(int argc, char *argv[])
{
  int a[11],i;
  printf ("please input numbers:\n");
  for(i=1;i<=10;i++)
    scanf("%d",&a[i]);
  shsort(a,10);
  printf ("the sorted numbers:\n");
  for(i=1;i<=10;i++)
    printf ("%5d",a[i]);
  return 0;
}

技巧06:快速排序(冒泡排序的改进)

主要的算法思想是在带排序的n个数据中取第一个数据作为基准值,将所有的记录分为3组,使得
第一组中各数据值均小于或等于基准值,第二组便是做基准值的数据,第三组中个数举值均大于
或等于基准值。这便实现了第一趟分隔,然后再对第一组和第三组分别重复上述方法。

#include <stdio.h>
void qusort(int s[],int start,int end)
{          //自定义快排函数
  int i,j;
  i=start;
  j=end;
  s[0]=s[start];            //设置基准值
  while(i<j)
    {
      while(i<j&&s[0]<s[j])
	j--;                //位置左移
      if (i<j)
	{
	  s[i]=s[j];        //将s[j]放到s[i]的位置上
	  i++;              //位置右移
	}
      while(i<j&&s[i]<=s[0])
	i++;                //位置右移
      if (i<j)
	{
	  s[j]=s[i];        //将大于基准值的s[j]放到s[i]位置
	  j--;              //位置右移
	}
    }
  s[i]=s[0];                //将基准值放入指定位置
  if(start<i)
    qusort(s,start,j-1);    //对分隔出的部分递归调用函数qusort()
  if(i<end)
    qusort(s,j+1,end);
}
int main(int argc, char *argv[])
{
  int a[11],i;
  printf ("please input numbers:\n");
  for(i=1;i<=10;i++)
    scanf("%d",&a[i]);
  qusort(a,1,10);
  printf ("the sorted numbers:\n");
  for(i=1;i<=10;i++)
    printf ("%5d",a[i]);
  return 0;
}

技巧07:顺序查找

#include <stdio.h>
void search(int key,int a[],int n)
{
  int i,count = 0,count1=0;
  for (i=0; i<n; i++)
    {
      count++;
      if (a[i]==key)
	{
	  printf ("serch %d times a[%d]=%d\n",count,i,key);
	  count1++;
	}
    }
  if(count1==0)
    printf ("no found!\n");
}
int main(int argc, char *argv[])
{
  int n,key,a[100],i;
  printf ("please input the length of array:\n");
  scanf("%d",&n);
  printf ("please input element:\n");
  for(i=0;i<n;i++)
    scanf("%d",&a[i]);
  printf ("please input the number which do you want to search:\n");
  scanf("%d",&key);
  search(key,a,n);
  return 0;
}

技巧08:二分查找

#include <stdio.h>
void binary_search(int key,int a[],int n)
{
  int low,high,mid,count=0,count1=0;
  low = 0;
  high = n-1;
  while(low<high)
    {
      count++;              //记录查找次数
      mid=(low+high)/2;     //求出中间位置
      if(key<a[mid])        //当key小于中间值
	high=mid-1;         //确定左子表范围
      else if(key>a[mid])   //当key大于中间值
	low=mid+1;          //确定右子表范围
      else if(key==a[mid])  //当key等于中间值证明查找成功
	{
	  printf ("success!\nsearch %d times! a[%d]=%d\n",count,mid,key);
	  count1++;         //count1记录查找成功次数
	  break;
	}
    }
  if(count1==0)
    printf ("no found!\n");
}
int main(int argc, char *argv[])
{
  int i,key,a[100],n;
  printf ("please input the length of array:\n");
  scanf("%d",&n);
  printf ("please input the element:\n");
  for(i=0;i<n;i++)
    scanf("%d",&a[i]);
  printf ("please input the number which do you want to serch:\n");
  scanf("%d",&key);
  binary_search(key,a,n);
  return 0;
}

技巧09:分块查找

#include <stdio.h>
struct index           //定义块的结构
{
  int key;
  int start;
  int end;
}index_table[4];       //定义结构体数组
int block_search(int key,int a[])          //自定义实现分块查找
{
  int i,j;
  i=1;
  while(i<=3&&key>index_table[i].key)      //确定在哪个块中
    i++;
  if(i>3)                                  //大于分得的块数,则返回0
    return 0;
  j=index_table[i].start;                  //j等于块范围的起始值
  while(j<=index_table[i].end&&a[j]!=key)  //在确定的块内进行查找
    j++;
  if(j>index_table[i].end)    //如果大于块范围的结束值,则说明没有要查找的数
    j=0;
  return j;
}
int main(int argc, char *argv[])
{
  int i,j=0,k,key,a[16];
  printf ("please input the number:\n");
  for(i=1;i<16;i++)
    scanf("%d",&a[i]);
  for (i=1; i<=3; i++)
    {
      index_table[i].start=j+1;    //确定每个范围的起始行
      j=j+1;
      index_table[i].end=j+4;      //确定每个块范围的结束值
      j=j+4;
      index_table[i].key=a[j];     //确定每个块范围中元素的最大值
    }
  printf ("please inpu the number whick do you want to search:\n");
  scanf("%d",&key);
  k=block_search(key,a);
  if(k!=0)
    printf ("success ! the position is :%d\n",k);
  else
    printf ("no found!\n");
  return 0;
}

技巧10:哈系查找(没能很好的运行)

#include <stdio.h>
#include <time.h>
#define Max 11
#define N 8
int hashtable[Max];
int func(int value)
{
  return value % Max;           //哈希函数
}
int search(int key)              //自定义函数实现哈希函数
{
  int pos,t;
  pos=func(key);                //哈希函数确定出的位置
  t=pos;                        //t存放确定出的位置
  while(hashtable[t]!=key && hashtable[t]!=-1)
       //如果该位置上不等与要查找的关键字且不为空
    {
      t=(t+1)%Max;              //利用线性探测求出下一个位置
      if(pos==t)
       //如果经多次探测又回到原来用哈希函数求出的位置则
       //说明要查找的数不存在
	return -1;
    }
  if(hashtable[t]==-1)          //如果探测的位置是-1则说明要查找的数不存在
    return 0;
  else
    return t;
}
void creathash(int key)         //自定义函数创建哈系表
{
  int pos,t;
  pos = func(key);              //哈希函数确定元素的位置
  t = pos;
  while(hashtable[t]!=-1)
       //如果该位置有元素存在则在则进行线性探测再散列
    {
      t=(t+1)%Max;
      if(pos==t)
       //如果冲突处理后确定的位置与原位置相同则说明哈系表已满
	{
	  printf ("hash table is full\n");
	  return ;
	}
    }
  hashtable[t]=key;              //将元素放入确定的位置
}
int main(int argc, char *argv[])
{
  int flag[50];
  int i,j,t;
  for(i=0;i<Max;i++)
    hashtable[i]=-1;             //哈希表中初始化位置全置-1
  for(i=0;i<50;i++)
    flag[i]=0;                   //50以内所有数未产生时均标志为0
  rand((unsigned long)time(0));  //利用系统时间做种子产生随机数
  i=0;
  while(i != N)
    {
      t=rand()%50;               //产生一个50以内的随机数附给t
      if (flag[t]=0)             //查看t是否产生过
	{
	  creathash(t);          //调用函数创建哈希表
	  printf ("%2d:\n",t);   //将该元素输出
	  for (j=0; j < Max; j++)
	    printf ("(%2d) \n",hashtable[j]);    //输出哈希表的内容
	  printf ("\n");
	  flag[t]=1;             //将产生的这个数标志为1
	  i++;                   //i自加
	}
    }
  printf ("please input number whick do you want to search:\n");
  scanf("%d",&t);                //输入要查找的元素
  if (t>0&&t<50)
    {
      i=search(t);               //调用search进行哈系查找
      if(i != -1)
	printf ("success! the position is:%d\n",i); //若找到该元素则输出其位置
      else
	printf ("sorry,no found!\n");               //未找到输出提示信息
    }
  else
    printf ("input error!\n");
  return 0;
}

文章出处:https://www.cnblogs.com/lyshark

以上就是C/C++ 常用排序算法整理汇总分享的详细内容,更多关于C/C++ 排序算法的资料请关注我们其它相关文章!

(0)

相关推荐

  • C/C++实现双路快速排序算法原理

    看了刘宇波的视频,讲双路快速排序的,原理讲的很直观,程序讲解也一看就懂.这里写一下自己的理解过程,也加深一下自己的理解. 首先说一下为什么需要双路排序,在有些带有许多重复数据的数组里,使用随机快速排序或者最简单的快速排序算法时,由于重复的数据会放在原来的索引位置不动,就回导致划分数组时划分的某一部分太长,起不到分段排序的效果,这样就导致算法退化成O(n^2)的复杂度.就像下图: 为了解决这个问题,双路快速排序采用的方法是对等于v的数也进行交换,原理如下所述: 首先选择一个数作为标志,放在数组的最

  • C++实现归并排序算法

    归并 归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用.将已有序的子序列合并,得到完全有序的序列:即先使每个子序列有序,再使子序列段间有序.若将两个有序表合并成一个有序表,称为二路归并. 算法描述 归并操作的工作原理如下: 1.申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列 2.设定两个指针,最初位置分别为两个已经排序序列的起始位置 3.比较两个指针所指向的元素,选择相对小

  • 详解C++实现链表的排序算法

    一.链表排序 最简单.直接的方式(直接采用冒泡或者选择排序,而且不是交换结点,只交换数据域) //线性表的排序,采用冒泡排序,直接遍历链表 void Listsort(Node* & head) { int i = 0; int j = 0; //用于变量链表 Node * L = head; //作为一个临时量 Node * p; Node * p1; //如果链表为空直接返回 if (head->value == 0)return; for (i = 0; i < head->

  • C/C++实现快速排序算法的思路及原理解析

    快速排序 1. 算法思想 快速排序的基本思想:通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序. 2. 实现原理 2.1.设置两个变量 low.high,排序开始时:low=0,high=size-1. 2.2.整个数组找基准正确位置,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面 默认数组的第一个数为基准数据,赋值给key,即key=array[low]. 因为默认数组的第一个

  • C++排序算法之插入排序

    本文实例为大家分享了C++排序算法之插入排序的具体代码,供大家参考,具体内容如下 1.基本思想:将未排序的数据元素按大小顺序插入到已排好序数据序列中,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入. 例如:对2, 4, 3, 1, 6, 5进行插入排序.进行排序前,默认2是有序的,为有序区,而4, 3, 1, 6, 5是无序的,为无序区.将这五个无序的数按从小到大的顺序插入到有序区. 第一趟排序:将4与有序区的2比较,若小于2则插到2前面,大于2插到2后面.操作后有序区为:{2,

  • C++实现双向冒泡排序算法

    本文实例为大家分享了C++实现双向冒泡排序算法的具体代码,供大家参考,具体内容如下 一.概念(来源于百度百科) 传统冒泡算法原理 冒泡排序算法的运作如下:(从后往前) 1.比较相邻的元素.如果第一个比第二个大,就交换他们两个. 2.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应该会是最大的数. 3.针对所有的元素重复以上的步骤,除了最后一个. 4.持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较. 双向冒泡算法原理 双向冒泡排序算法的运作如

  • 详解C++实现拓扑排序算法

    一.拓扑排序的介绍 拓扑排序对应施工的流程图具有特别重要的作用,它可以决定哪些子工程必须要先执行,哪些子工程要在某些工程执行后才可以执行.为了形象地反映出整个工程中各个子工程(活动)之间的先后关系,可用一个有向图来表示,图中的顶点代表活动(子工程),图中的有向边代表活动的先后关系,即有向边的起点的活动是终点活动的前序活动,只有当起点活动完成之后,其终点活动才能进行.通常,我们把这种顶点表示活动.边表示活动间先后关系的有向图称做顶点活动网(Activity On Vertex network),简

  • C++插入排序算法实例详解

    本文实例为大家分享了C++插入排序算法实例的具体代码,供大家参考,具体内容如下 基本思想 每次将一个待排序的元素,按其大小插入到已经排好序的子序列的适当位置,知道全部元素插入完成为止. 直接插入排序 1.排序思路 arr[0...i-1]为有序区(刚开始时i=1,有序区只有arr[0]一个元素),arr[i...size]为待排序区,每次将待排序区的第一个元素arr[i]插入到有序区中的适当位置,每趟操作都使有序区增加一个元素,待排序区减少一个元素. 2.排序算法 void InsertSort

  • C/C++实现三路快速排序算法原理

    书接上文,上次讲到了双路快速排序,双路快速排序是将等于v(标志数)的数也进行交换,从而避免了在处理有大量重复数据的数组分组时的不平衡.而三路快速排序则是将等于v的数也分成一组,同样可以解决上述问题.其原理如下: 1.采用随机排序的方法将某个数作为分割数,放在数组开头,该数定义为v.将小于v的一段数组开头的数索引定义为lt,将需要遍历的数组的索引定义为i,将小于v的一段数组的索引定义为gt,数组的开头和结尾的索引分别为l和r.原理图如下: 2.对索引i进行维护,逐个比较索引i对应的数与v的关系.如

  • C++选择排序算法实例详解

    本文实例为大家分享了C++选择排序算法的具体代码,供大家参考,具体内容如下 基本思想 每一趟从无序区中选出最小的元素,顺序放在有序区的最后,直到全部元素排序完毕. 由于选择排序每一趟总是从无序区中选出全局最小(或最大)的元素,所以适用于从大量元速度中选择一部分排序元素.例如,从10000个元素中选出最小的前10位元素. 直接选择排序 1.排序思路 从第i趟开始,从当前无序区arr[i-n-1]中选出最小元素arr[k],将它与有序区的最后一个元素,也就是无序区的第一个元素交换.每趟排序后,有序区

随机推荐