首页 > 编程语言 > 详细

选择排序

时间:2017-04-14 20:32:55      阅读:194      评论:0      收藏:0      [点我收藏+]

选择排序(如果递增排序)

每次选取从当前结点到末尾结点中最小的一个与当前结点交换,每一轮固定一个元素位置。

时间复杂度O(n^2),空间复杂度O(1)。以下的演示样例代码以带头结点的链表为存储结构:

#include<stdio.h>
#include<stdlib.h>
#define Elemtype double
struct Node
{
	Elemtype data;
	struct Node *next;
};
void listsort(Node*h)
{
	Node*p=h->next;
	while(p!=NULL)
	{
		Node*q=p;
		Node*k=p;
		Elemtype min=p->data;
		while(q!=NULL)
		{
			if(min>q->data)
			{
				min=q->data;
				k=q;
			}
			q=q->next;
		}
		Elemtype tmp=p->data;
		p->data=k->data;
		k->data=tmp;
		p=p->next;
	}
}
int main()
{
	Node*h=(Node*)malloc(sizeof(Node));
	h->next=NULL;
	for(int i=0;i<10;i++)
	{
		Node*p=(Node*)malloc(sizeof(Node));
		scanf("%lf",&p->data);
		p->next=h->next;
		h->next=p;
	}
	listsort(h);
	Node*q=h->next;
	while(q!=NULL)
	{
		printf("%lf\n",q->data);
		q=q->next;
	}
	return 0;
}


选择排序

原文:http://www.cnblogs.com/brucemengbm/p/6710641.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!