链表实现冒泡排序算法

 

 

// TEST2.cpp : Defines the entry point for the console application.
//

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


int main(int argc, char* argv[])
{
	int a = 0, i = 0;
	int *arr = NULL;
	struct Node{
		int num;
		struct Node* next;
	};
	struct Node *Head, *pTmp, *pPre, *tHead, *pLast;

	while (1 == scanf("%d",&a)){
		pTmp = (struct Node *)malloc(sizeof(struct Node));
		if(pTmp == NULL){
			return 0;
		}
		pTmp->num = a;
		pTmp->next = NULL;
		if(i++ == 0){
			Head = pTmp;
			pPre = pTmp;
		}else{
			pPre->next = pTmp;
			pPre = pTmp;
		}
	}

	for(int j=0; j<i; j++ ){
		for(pPre = Head, pTmp = Head->next;  pTmp != NULL;  pPre = pTmp, pTmp = pTmp->next ){	
			if(pPre->num > pTmp->num){
			int nTmp = pPre->num;
			pPre->num = pTmp->num;
			pTmp->num = nTmp;		
			}			
		}
			
	}
	

	pTmp = Head;
	while (pTmp != NULL){
		printf("%d ",pTmp->num);
		pTmp = pTmp->next;
	}
	printf("\n");
	
	getchar();
	return 0;
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值