- 1、本文档共36页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构学习整理
中国海洋大学
信息科学与工程学院
海大新星
2012 年 1 月 7 日星期六
联系:447805280
1 / 36
1.数组和链表的区别。
C++语言中可以用数组处理一组数据类型相同的数据,但不允许动态定义数组的大小,即在
使用数组之前必须确定数组的大小。而在实际应用中,用户使用数组之前有时无法准确确定
数组的大小,只能将数组定义成足够大小,这样数组中有些空间可能不被使用,从而造成内
存空间的浪费。链表是一种常见的数据组织形式,它采用动态分配内存的形式实现。需要时
可以用 new 分配内存空间,不需要时用 delete 将已分配的空间释放,不会造成内存空间的
浪费。
从逻辑结构来看:数组必须事先定义固定的长度(元素个数),不能适应数据动态地增减的
情况,即数组的大小一旦定义就不能改变。当数据增加时,可能超出原先定义的元素个数;
当数据减少时,造成内存浪费;链表动态地进行存储分配,可以适应数据动态地增减的情况,
且可以方便地插入、删除数据项。(数组中插入、删除数据项时,需要移动其它数据项)。
从内存存储来看:(静态)数组从栈中分配空间(用 NEW 创建的在堆中), 对于程序员方便
快速,但是自由度小;链表从堆中分配空间, 自由度大但是申请管理比较麻烦.
从访问方式来看:数组在内存中是连续存储的,因此,可以利用下标索引进行随机访问;链
表是链式存储结构,在访问元素的时候只能通过线性的方式由前到后顺序访问,所以访问效
率比数组要低。
2.单链表插入元素
#include iostream p=(struct Node
using namespace std; *)malloc(LEN);
#define LEN sizeof (struct Node) cinp-date;
struct Node{ p1-next=p;
int date; }
struct Node *next; p-next=NULL;
}; p=head;
int main(){ while (p-next!=0)
struct Node *p,*p1,*head; { coutp-date , ;
head=p=(struct Node p=p-next;
*)malloc(LEN); }
cinp-date; coutp-date;
while (p-date!=0) return 0;
{ }
p1=p;
3.删除节点值为8的节点:
p=head; p=head;
if (p==NULL) }
{ p1=p;
exit(0); p=p-next;
} while (p!=NULL)
while (head-date==8) {
{
您可能关注的文档
最近下载
- 《2023年甘肃省职业院校技能大赛职业英语技能赛项职业英语能力测试模块试题口语决赛样题》.pdf
- 建筑工程建筑面积计算规范GBT50353-2022[13].pdf
- JB/T 9628-1999 汽轮机叶片 磁粉探伤方法.pdf
- 0i-TF PLUS车床操作说明书.pdf
- 陈传明管理学笔记1.马工程——总论.pdf
- 06J925-2 压型钢板、夹芯板屋面及墙体建筑构造(二).docx VIP
- 《高速公路基础设施数字化建设数据标准》.pdf VIP
- 计算机组装与维护 知识点整理.pdf VIP
- 《员工满意度研究国内外文献综述》3900字.docx VIP
- 勤俭节约主题班会 主题班会.ppt VIP
文档评论(0)