- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构用面向对象方法与C++语言描述第二版殷人昆编著清华大学出版社课件;课程介绍;数据结构;如何学习?;上机实习作业:;第一章 绪论;;;;例1 书目自动检索系统;例2 人机对奕问题(井字棋)
;例2 人机对奕问题;例3 多叉路口交通灯管理问题;例3 多叉路口交通灯管理问题;;;;;;;内容回顾:;;继承:是面向对象方法最有特色的方面。
派生类:载重车,轿车,摩托车,…
子类、特化类(特殊化类)
基类:车辆
父类、超类、泛化类(一般化类)
各派生类中的公共部分???包括属性和服务,集中到基类中,派生类中只保留自己特有的属性和服务。这样减少了数据的存储和程序代码的重复。
通信
各个类的对象间通过消息传递进行通信。
消息:一个类的对象要求另一个类的对象执行某个服务的指令,必要时还要传递调用参数。;;;;;;;;(3)可行性 一个算法是可行的。即算法描述的操作都是可以通过已经实现的基本运算执行有限次来实现的。
(4)输入 一个算法有零个或多个输入,这些输入取自于某个特定的对象集合。
(5)输出 一个算法有一个或多个输出,这些输出是同输入有特定关系的量。;;怎样才能设计一个好的算法呢?;;;;;;;;;;;;;;;;;;作业:;第二章 线性表;2.1 线性表
2.2 顺序表
2.3 单链表
2.4 线性链表的其它变形
2.5 单链表的应用:一元多项式及其运算
;2.1 线性表 linear list;说明:;线性表的抽象数据类型:;2.1.2 线性表的类定义;2.2 顺序表(Sequential List); 顺序表可以用C++的一维数组来实现。 C++的一维数组可以是静态分配的,也可以是动态分配的。
;2.2.2顺序表(SeqList)类的定义;int Length ( ) const { return last+1; } //返回元素的个数
int Find (T x ) const; //返回元素x在表中的位置
void Insert (T x, int i ); //在位置i插入元素x
int Remove (T x ); //删除值为x的元素
int IsEmpty ( ) { return last ==-1; } //表空否
int IsFull ( ) { return last == MaxSize-1; }
T GetData ( int i ) { //取第i个表项的值
return data[i-1] };
void SetData ( int i, T x) { //为第i个表项赋值
if (i 0 i = last+1) data[i-1] = x ;}
void input();
void output();
} ;顺序表部分公共操作的实现:;②搜索或定位:;int SeqList::Find ( T x ) const {
//搜索函数:在表中从前向后顺序查找 x
int i = 0;
while ( )
i++;
if ( i last ) return -1; else return i+1;
};搜索成功:
若搜索概率相等,则
搜索不成功 数据比较 n 次; (a1, …, ai-1, ai, …, an) 改变为(a1, …, ai-1, x, ai, …, an);21 18 30 75 42 56 87;Insert ( const T x, int i) 思路:;//在指定位置i插入一个数据元素x
void SeqList::Insert ( const T x, int i)
{//i为下标,不是序号
if(last == MaxSize-1)
{
cerr“顺序表已满无法插入!”endl;exit(1);
}
if(i0‖ilast+1)
//当i等于Last+1时表示插入在最后
{ cerr参数i越界出错!endl; exit(1);
}
;
//从后向前把前一个元素迁移到后一个元素位置直到存储位置为i为止
last++;//当前最后元素下标加1
for(int j = Las
文档评论(0)