网站大量收购独家精品文档,联系QQ:2885784924

东华大学数据结构 参照严蔚敏版.ppt

  1. 1、本文档共437页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《数 据 结 构》 东华大学计算机系 教学目录 1.1 本课程研究的问题 1.1 本课程研究的问题 例 3 迷宫问题。在迷宫中,每走到一处,接下来可走的通路有三条。计算机处理的这类对象之间通常不存在线性关系。若把从迷宫入口处到出口的过程中所有可能的通路都画出,则可得一棵“树” 城市间交通网问题 1.1 本课程研究的问题 1.2 数据结构的有关概念 1.2 数据结构的有关概念 1.3 数据结构的分类及表示 1.4 算法与算法分析 描述算法的书写规则 所有算法均以函数形式给出, 算法的输入数据来自参数表 参数表的参数在算法之前均进行类型说明 有关结点结构的类型定义,以及全局变量的说明等均在算法之前进行说明 解法2 # define N 100 Void scheme( ) { int i, j; for (i=0; i=N/3; i++) for (j=0; j=(N-3*i)/2; j++) { if (3*i+2*j+0.5*(N-i-j)= =N) printf(“%d, %d, %d\n%”, i, j, N-i-j); } } 时间复杂度为O(N2 ) 第二章 线性表 第二章 线性表 2. 1 线性表的概念 2.1 线性表的概念 2.1 线性表的概念 2.1 线性表的概念 2.1 线性表的概念 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 二、顺序表的基本操作算法 插入 insert(v, x, i) 功能:在顺序表v 中的第 i ( 1=i=n+1)个数据元素之前插入一个新元素x, 插入前线性表为 (a1, a2, a3,…, ai-1 ,ai,,… an ) 插入后,线性表长度为n+1, 线性表为 (a1, a2, a3,…, ai-1 , x, ai,,… an ) 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.2 线性表的顺序存储和实现 2.3 线性表的链式存储和实现 2. 3. 1 线性链表 2. 3. 1 线性链表 2. 3. 1 线性链表 2. 3. 1 线性链表 2. 3. 1 线性链表 2.3 线性链表 2.2 线性链表 2. 3. 1 线性链表 2.3.1 线性链表 建立链表 NODE *create_link(n) /*建立有n个结点的线性单链表的算法 { NODE *head, *p, *q; int i; p=( NODE *)malloc(sizeof(NODE));head=p; for(i=I;I=n;i++) {q= ( NODE *)malloc(sizeof(NODE)); q-data=i; q-link=NULL; p-link=q;p=q; } return(head); } 插入结点 q=(NODE *)malloc(sizeof(NODE)); q-deta=‘a’; q-link=p-link; p-link=q; 2. 3. 1 线性链表 2. 3. 1 线性链表 Int insert_link(NODE *head,int x, int i) { NODE *p,*s;int j; p=head;j=0; while ((p!=NULL)(ji-1)) {p=p-link;j++;} if(p==NULL)return(0); s=(NODE *(malloc(sizcof(NODE)); s-data=x; s-link=p-link; p-link=s; return(1); } 删除结点 q=p-link; p-link=q-link; free(q); 2. 3. 1 线性链表 在线性链表中删除第i个结点 Int delete_link(NODE *head, int i) { NODE *p,*q;int j; p=head;j=0; while ((p!=NULL)(ji-1))

您可能关注的文档

文档评论(0)

小教资源库 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档