- 1、本文档共14页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构c 语言版习题集答案
【篇一:数据结构(c 语言版)第三版 清华大学出版社_ 习题参考答案】
习题 1 参考答案1.1.选择题
(1). a. (2). a. (3). a. (4). b.,c. (5). a. (6). a. (7). c. (8). a. (9). b. (10.)
a.
1.2.填空题(1). 数据关系
逻辑结构物理结构
线性数据结构 树型结构图结构
顺序存储链式存储索引存储散列表(hash)存储
变量的取值范围操作的类别
数据元素间的逻辑关系 数据元素存储方式或者数据元素的物理关系
关系网状结构树结构
空间复杂度和时间复杂度
空间 时间
名词解释如下:
数据:数据是信息的载体,是计算机程序加工和处理的对象,包括 数值数据和非数值数据。 数据项:数据项指不可分割的、具有独立意义的最小数据单位,数据项有时也称为字段或域。 数据元素:数据元素是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理,一个数据元素可由若干个数据项组成。
数据逻辑结构:数据的逻辑结构就是指数据元素间的关系。
数据存储结构:数据的物理结构表示数据元素的存储方式或者数据 元素的物理关系。 数据类型:是指变量的取值范围和所能够进行的操作的总和。
算法:是对特定问题求解步骤的一种描述,是指令的有限序列。
语句的时间复杂度为:
参考程序:
main()
{
int x,y,z;
scanf(“%d, %d, %d”,x,y,z);
if (x=y) if(x=z) if (y=z)
{ printf(“%d, %d, %d”,x,y,z);}
else
{ printf(“%d, %d, %d”,x,z,y);}
else
{ printf(“%d, %d, %d”,z,x,y);}
else if(z=x) if (y=z)
{ printf(“%d, %d, %d”,y,z,x);}
else
{ printf(“%d, %d, %d”,z,y,x);}
else
{ printf(“%d, %d, %d”,y,x,z);}
}
参考程序:
main()
{
int i,n;
float x,a[],p;
printf(“\nn=”);scanf(“%f”,n);
printf(“\nx=”);scanf(“%f”,x);
for(i=0;i=n;i++) scanf(“%f ”,a[i]); p=a[0];
for(i=1;i=n;i++)
{ p=p+a[i]*x; x=x*x;} printf(“%f”,p)’
}
习题 2 参考答案
2.1 选择题
(1). c. (2). b. (3). b. (4). b. 5. d. 6. b. 7. b.8. a.9. a.10. d.
填空题(1). 有限序列
顺序存储和链式存储
O(n)o(n)
n-i+1 n-i
链式
数据指针
前驱后继
(9). s-next=p-next; p-next=s ;
解题思路:将顺序表 a 中的元素输入数组 a,若数组 a 中元素个数为 n,将下标为 0,
1,2,?,(n-1)/2 的元素依次与下标为 n,n-1,?,
输出数组 a 的元素。参考程序如下: main()
{
int i,n; float t,a[];
printf(“\nn=”);scanf(“%f”,n);
for(i=0;i=n-1;i++)
scanf(“%f ”,a[i]);
for(i=0;i=(n-1)/2;i++)
{ t=a[i]; a[i] =a[n-1-i];a[n-1-i]=t;} for(i=0;i=n-1;i++) printf(“%f”,a[i]);
}
算法与程序:
main()
{
int i,n; float t,a[];
printf(“\nn=”);scanf(“%f”,n);
for(i=0;in;i++) scanf(“%f ”,a[i]); for(i=1;in;i++) if(a[i]a[0])
{ t=a[i]; a[i] =a[0];a[0]=t;} printf(“%f”,a[0]); for(i=2;in;i++)
if(a[i]a[1])
{ t=a[i]; a[i] =a[1];a[1]=t;}
printf(“%f”,a[0]);
(n-1)/2 的元素交换,
}
算法与程序:
main()
{
int i,j,k,n;
float x,t,a[];
printf(“\nx=”);scanf(“%f”,x);
printf(“\nn=”);scanf(“%f”,n);
for(i=0;in;i++)
scanf(“%f ”,a[i]);// 输入线性表中的元素
for (i=0; in; i++) {
文档评论(0)