第五章 数组和广义表

习 题

1. 假设有6行8列的二维数组A,每个元素占用6个字节,存储器按字节编址。已知A的基地址为1000,计算:

(1) 数组A共占用多少字节; (288) (2) 数组A的最后一个元素的地址; (1282) (3) 按行存储时,元素A36的地址; (1126) (4) 按列存储时,元素A36的地址; (1192) [注意]:本章自定义数组的下标从1开始。

2.设有三对角矩阵(aij)n×n ,将其三条对角线上的元素逐行地存于数组B(1:3n-2)中,使得B[k]= aij ,求:

(1) 用i,j表示k的下标变换公式; (2) 用k表示i,j的下标变换公式。

i = k/3 + 1, j = k%3 + i - 1 = k%3 + k/3 或:

i = k/3 + 1, j = k - 2×( k/3 )

3. 假设稀疏矩阵A和B均以三元组表作为存储结构。试写出矩阵相加的算法,另设三元组表C存放结果矩阵。

[提示]:参考P.28例、P.47例。

4.在稀疏矩阵的快速转置算法5.2中,将计算position[col]的方法稍加改动,使算法

只占用一个辅助向量空间。 [提示]: (1) (2) (3) (4)

5.写一个在十字链表中删除非零元素aij的算法。 [提示]:“删除”两次,释放一次。

position[ k ] 中为第k列非零元素个数,k = 1, 2, …, n position[ 0 ] = 1; (第1列中第一个非零元素的正确位置) position[ k ] = position[ k – 1 ] + position[ k ] , k = 1, 2, …, n position[ k ] = position[ k – 1 ] , k = n, n – 1 , … ,1

6.画出下面广义表的两种存储结构图示: ((((a), b)), ((( ), d), (e, f)))

0 a 1 1 1 ∧ ∧ 0 b 1 ∧ 0 d 1 ∧ 1 1 1 ∧ 1 1 1 0 e ∧ ∧ 1 0 f ∧ 第一种存储结构(自底向上看)

7.求下列广义表运算的结果: (1) HEAD[((a,b),(c,d))]; (2) TAIL[((a,b),(c,d))]; (3) TAIL[HEAD[((a,b),(c,d))]];

(4) HEAD[TAIL[HEAD[((a,b),(c,d))]]]; b (5) TAIL[HEAD[TAIL[((a,b),(c,d))]]]; (d)

参考题

8.试设计一个算法,将数组A(0:n-1)中的元素循环右移k位,并要求只用一个元素大小的附加存储,元素移动或交换次数为O(n)。

9.假设按低下标优先(以最左的下标为主序)存储整数数组A(1:8, 1:2, 1:4, 1:7)时,第一个元素的字节地址是100,每个整数占4个字节,问元素A(4, 2, 3, 5)的存储地址是什么? 10. 高下标优先(以最右的下标为主序)存储整数数组A(1:8, 1:2, 1:4, 1:7)时,顺序列出数组A的所有元素。

11.试编写一个以三元组形式输出用十字链表表示的稀疏矩阵中非零元素及其下标的算法。

实习题

1. 若矩阵Am×n中的某个元素aij是第i行中的最小值,同时又是第j列中的最大值,则称此

元素为该矩阵中的一个马鞍点。假设以二维数组存储矩阵,试编写算法求出矩阵中的所有马鞍点。

第五章答案

5.2 三对角矩阵An×n,将其三条对角线上的元素逐行的存于数组B[1..3n-2]中,使得B[k]=aij,求:(1)用i,j表示k的下标变换公式; (2)用k表示i、j的下标变换公式。 【解答】(1)k=2(i-1)+j

(2) i=[k/3]+1, j=[k/3]+k%3 ([ ]取整,%取余)

5.4 稀疏矩阵的快速转置算法5.2中,将计算position[col]的方法稍加改动,使算法只占用一个辅助向量空间。 【解答】 算法(一)

FastTransposeTSMatrix(TSMartrix A, TSMatrix *B) {/*把矩阵A转置到B所指向的矩阵中去,矩阵用三元组表表示*/

int col,t,p,q;

int position[MAXSIZE];

B->len=A.len; B->n=A.m; B->m=A.n; if(B->len>0) {

position[1]=1; for(t=1;t<=A.len;t++)

position[A.data[t].col+1]++; /*position[col]存放第col-1列非零元素的个数,

即利用pos[col]来记录第col-1列中非零元素的个数*/

/*求col列中第一个非零元素在B.data[ ]的位置,存放在position[col]中*/ for(col=2;col<=A.n;col++)

position[col]=position[col]+position[col-1]; for(p=1;pcol=A.data[p].col;

q=position[col];

B->data[q].row=A.data[p].col; B->data[q].col=A.data[p].row; B->data[q].e=A.data[p].e; Position[col]++; } } } 算法(二)

FastTransposeTSMatrix(TSMartrix A, TSMatrix *B) {

int col,t,p,q;

int position[MAXSIZE];

B->len=A.len; B->n=A.m; B->m=A.n; if(B->len>0) {

for(col=1;col<=A.n;col++) position[col]=0; for(t=1;t<=A.len;t++)

position[A.data[t].col]++; /*计算每一列的非零元素的个数*/

// 从最后一列起求每一列中第一个非零元素在B.data[]中的位置, // 放在position[col]中*/

for(col=A.n,t=A.len;col>0;col--) { t=t-position[col]; position[col]=t+1; }

for(p=1;pcol=A.data[p].col; q=position[col];

B->data[q].row=A.data[p].col; B->data[q].col=A.data[p].row; B->data[q].e=A.data[p].e;

数据结构c语言描述的习题答案,《数据结构 - C语言描述》习题及答案 耿国华-...相关推荐

  1. c语言用指针求Amn,[工学]第5章数据结构C语言描述耿国华.ppt

    [工学]第5章数据结构C语言描述耿国华 j=1;  for(k=1; k<=A.n; k++)  for(i=1; i<=A.len; i++) if(A.data[i].col== ...

  2. 耿国华c语言程序设计,C语言程序设计课程教学探究.doc

    C语言程序设计课程教学探究 C语言程序设计课程教学探究 摘 要:C语言程序设计课程作为一门基础的计算机程序设计课程,其对于计算机教学具有重要的意义,同时也是许多院校理工科学生的必修课程.本文阐述了C语 ...

  3. 数据结构——用C语言描述(第2版)耿国华 课后习题答案

    如有错误,敬请谅解! 此文章仅为本人学习笔记,仅供参考,如有冒犯,请联系作者删除!! 目录 第一章习题答案 第二章习题答案 第三章习题答案 第五章习题答案 第六章习题答案 第七章习题答案 第八章查找 ...

  4. 数据结构 耿国华老师讲

    第一章$绪论 第一讲$数据结构的基础 数据是表征客观事物的可记录可识别的符号集合.数据是信息处理的核心基础. 数据结构有关的基本概念术语: 1.数据 2.数据元素 3.数据对象 4.数据类型 5.数据 ...

  5. 数据结构 耿国华 第三版

    前言:本人在各大网站都查过答案,但是答案版本和第三版都不一样,只是有个别大题重复,在以下整理的答案为自己所做,如有不对之处,不承担任何后果. 第三章 B 考察队列的应用 C C C 取一个n和i 自己 ...

  6. 《数据结构-耿国华第三版》算法要点总结

    一.线性表 1.顺序表中删除所有值为x的元素,时间复杂度为O(n) 若采用从头遍历并删除 则O(n方) 思想:在原表基础上重建一个不含值为x的元素 使用2个指示器 m=0,n=0; while(m!= ...

  7. 哈夫曼树的一个实例,配对严蔚敏或耿国华的数据结构

    /*这是一个哈弗曼编码的完整实例,没什么含量,只是爱X当时闲书上的写的不*/ #include <stdio.h> #include <stdlib.h> #include & ...

  8. 23V3有这种C语言表达式吗,数据结构(C语言版第2版_李云清)习题答案2012-12.doc

    数据结构(C语言版第2版_李云清)习题答案2012-12.doc 第 1 章 绪论 1.1 什么是数据结构? [答]:数据结构是指按一定的逻辑结构组成的一批数据,使用某种存储结构将这批数据存储 于计算 ...

  9. 数据结构(C语言版)(第2版) 课后习题答案

    文章目录 第1章 绪论 第2章 线性表 第3章 栈和队列 第1章 绪论 1.简述下列概念:数据.数据元素.数据项.数据对象.数据结构.逻辑结构.存储结构.抽象数据类型. 答案: 数据:是客观事物的符号 ...

最新文章

  1. CVPR2021(Oral) 商汤、港中文实现单目人脸重建新突破: 基于生成网络的渲染器!几何形状更精准!渲染效果更真实!...
  2. js计算前三个月的时间精确到时分秒
  3. 虚拟机Linux下解决ping时出现 unknown host问题
  4. pythonisalpha函数计算公式_常用python实现.ipynb
  5. 电路邱关源第五版pdf_硬件狗教你学电路【二】:电路分析方法
  6. server2008密码不满足密码策略的要求,检查最小密码长度、密码复杂性和密码历史的要求”的解决办法...
  7. hashmap put复杂度_集合类HashMap,HashTable,ConcurrentHashMap区别?
  8. ubuntu12.04 php环境搭建,Ubuntu12.04筹建php开发环境
  9. 【bzoj 3531】 [Sdoi2014]旅行(树链剖分+树套树)
  10. fan类java_Java常用类
  11. 光猫上网问题 看我如何解决
  12. linux监控程序-程序自动重启方法(转)
  13. android版信用卡还款提醒器
  14. ES(二)| 安装ES、Kibana、IK分词器、拼音分词器(自动补全)
  15. 365天英语口语学习_11,收拾餐桌碗碟
  16. 如何将两个excel表格合并
  17. 2019测试工程师面试题
  18. 【程序人生】1024 程序员节——闲言鹤语
  19. 2021年中国服装行业经营现状及重点企业对比分析[图]
  20. Sonatype Nexus Repository Manager

热门文章

  1. Vue+SpringBoot进销存管理系统源码【源码免费分享】
  2. 运放--单端信号转差分信号
  3. CreateSemaphore与ReleaseSemaphore
  4. 计算机安装打印机 心得,[转载]win64位下的老式打印机驱动安装心得(转)
  5. Outlook开机自启+关闭时最小化
  6. 获取铁矿石和螺纹钢期货数据。对收益率序列进行描述性统计、jb检验,反正是否符合分形市场假说。计算Hurst指数,制定跨品种套利策略,并进行回测,对跨品种套利效果进行评估。寻求改进空间。
  7. js获取对象里数据条数
  8. 学Python容易找工作嘛?
  9. citus 系列6 - count(distinct xx) 加速 (use 估值插件 hll|hyperloglo
  10. 微信小程序扫描二维码条形码