【郝斌数据结构自学笔记】26_通过链表排序算法的演示再次详细讨论到底什么是算法以及到底什么是泛型【重点】

原创 2015年11月21日 01:38:42

26_通过链表排序算法的演示再次详细讨论到底什么是算法以及到底什么是泛型【重点】


算法:

狭义的算法是与数据的存储方式密切相关

广义的算法是与数据的存储方式无关

泛型:

                   利用某种技术达到的效果就是:不同的存储方式,执行的操作是一样的

#include<stdio.h>

#include<malloc.h>

#include<stdlib.h>

 

typedefstruct Node

{

         int data;//数据域

         struct Node * pNext;//指针域

}NODE,*PNODE;//NODE等价于structNode,PNODE等价于struct Node *

//函数声明

PNODEcreate_list(void);

voidtraverse_list(PNODE pHead);

boolis_empty(PNODE pHead);

intlength_list(PNODE);

boolinsert_list(PNODE,int,int);

booldelete_list(PNODE,int,int*);

voidsort_list(PNODE);

 

 

intmain(void)

{

         PNODE pHead=NULL;//等价于structNode *pHead=NULL;

         pHead=create_list();//creat_list()功能:创建一个非循环单链表,并将该链表的头节点的地址付给pHead

         traverse_list(pHead);

         int len=length_list(pHead);

         printf("链表长度是%d\n",len);

 

         if(is_empty(pHead))

                   printf("链表为空!\n");

         else

                   printf("链表不空!\n");

         sort_list(pHead);

         traverse_list(pHead);

 

 

         return 0;

}

 

PNODEcreate_list(void)

{

         int len;//用来存放有效节点的个数

         int i;

         int val;//用来临时存放用户输入的节点的值

 

         //分配了一个不存放有效数据的头节点

         PNODEpHead=(PNODE)malloc(sizeof(NODE));

         if(NULL==pHead)

         {

                   printf("分配失败,程序终止!\n");

                   exit(-1);

         }

         PNODE pTail=pHead;

         pTail->pNext=NULL;

         printf("请输入您需要生成的链表节点的个数:len=");

         scanf("%d",&len);

 

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

         {

                   printf("请输入第%d个节点的值:",i+1);

                   scanf("%d",&val);

 

                   PNODEpNew=(PNODE)malloc(sizeof(NODE));

                   if(NULL==pNew)

                   {

                            printf("分配失败,程序终止!\n");

                            exit(-1);

                   }

                   pNew->data=val;//挂

                   pTail->pNext=pNew;

                   pNew->pNext=NULL;

                   pTail=pNew;

        

         }

         return pHead;

}

 

voidtraverse_list(PNODE pHead)

{

         PNODE p=pHead->pNext;

         while(NULL!=p)

         {

                   printf("%d",p->data);     

                   p=p->pNext;//不连续,不能用p++

         }

         printf("\n");

         return;

}

 

boolis_empty(PNODE pHead)

{

         if(pHead->pNext==NULL)

                   return true;

         else

                   return false;

}

 

intlength_list(PNODE pHead)

{

         PNODE p=pHead->pNext;

         int len=0;

         while(NULL!=p)

         {

                   len++;

                   p=p->pNext;

         }

         return len;

}

 

voidsort_list(PNODE pHead)

{

         int i,j,t;

         int len=length_list(pHead);

         PNODE p,q;

         for(i=0,p=pHead->pNext;i<len-1;++i,p=p->pNext)

         {

                   for(j=i+1,q=p->pNext;j<len;++j,q=q->pNext)

                   {

                            if(p->data>q->data)//类似于数组中的:a[i]>a[j]

                            {

                                     t=p->data;//类似于数组中的:     t=a[i];

                                     p->data=q->data;//类似于数组中的: a[i]=a[j];

                                     q->data=t;//类似于数组中的:     a[j]=t;

                            }

                   }

         }

 

}


版权声明:本文为博主原创文章,未经博主允许不得转载。

跟着郝斌学数据结构(01)——预备

数据结构概述 定义 我们如何把现实中大量而复杂的问题以特定的数据类型和特定的存储结构保存到主存储器(内存)中,以及在此基础上为实现某个功能(比如查找某个元素,删除某个元素,对所有元素进行排序)而执行的...
  • xxssyyyyssxx
  • xxssyyyyssxx
  • 2016年05月15日 12:59
  • 972

郝斌数据结构  26 通过链表排序算法的演示 再次详细讨论到底什么是算法和泛型

#include #include #include #include typedef struct Node { int data; //数据域 str...
  • asty008
  • asty008
  • 2016年12月21日 11:54
  • 197

数据结构笔记(郝斌主讲)(2015-11-26 22:16:36更新完毕)

教材-课外书籍推荐 高一凡(伪算法→真代码) 数据结构概述 定义 我们如何把现实生活中大量而复杂的问题以特定的数据类型和特定的存储结构保存到主存储器(内存)中,以及在此基础上为实现某个功能(比...
  • juliantem
  • juliantem
  • 2015年08月21日 12:46
  • 703

跟着郝斌学数据结构(03)——链表【基本概念】

typedefine的使用:为了减少书写的麻烦,可以将一个结构体的定义用另外一个名称来代替。 typedefine struct Student { int sid; char[20] nam...
  • xxssyyyyssxx
  • xxssyyyyssxx
  • 2016年05月15日 17:42
  • 548

跟着郝斌学数据结构(04)——链表【链表的操作】

# include # include # include typedef struct Node { int data; //数据域 struct Node * pNext; //指针域...
  • xxssyyyyssxx
  • xxssyyyyssxx
  • 2016年05月15日 18:28
  • 295

【郝斌数据结构自学笔记】75-78_链式二叉树遍历具体程序演示_5种常用排序概述和快速排序详细讲解_再次讨论什么是数据结构_再次讨论到底什么是泛型

75_树16_链式二叉树遍历具体程序演示 //程序执行有问题 #include #include   struct BTNode {          intdata;  ...
  • NewNicholas
  • NewNicholas
  • 2015年12月07日 00:06
  • 987

【分享】郝斌老师C语言 教程 1 到 180课

1到10课 郝斌老师C语言1-10.rar (55.18 MB) ed2k://|file|%E9%83%9D%E6%96%8C%E8%80%81%E5%B8%88C%E8%AF%AD%E8%A8...
  • abc4715760
  • abc4715760
  • 2014年11月11日 00:35
  • 3184

郝斌老师的链表算法演示

/* list.c 代码是在看视频时跟着敲的,如有错误请指正 用的编译器:c-free*/ #include #include #include typedef struct Node { in...
  • juliantem
  • juliantem
  • 2015年09月21日 20:58
  • 393

郝斌数据结构笔记

数据结构定义:        我们如何把现实中大量而复杂的问题以特定的数据类型和特定的存储结构保存到主存储器(内存)中,以及在此基础上为实现某个功能而执行的相应的操作(比如查找某个元祖,删除某个元素...
  • qintian888
  • qintian888
  • 2017年02月28日 18:47
  • 196

【郝斌数据结构自学笔记】25_判断链表是否为空和求链表长度算法的演示

25_判断链表是否为空和求链表长度算法的演示 #include #include #include   typedefstruct Node {          int data;//...
  • NewNicholas
  • NewNicholas
  • 2015年11月21日 01:33
  • 569
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【郝斌数据结构自学笔记】26_通过链表排序算法的演示再次详细讨论到底什么是算法以及到底什么是泛型【重点】
举报原因:
原因补充:

(最多只允许输入30个字)