1100 1149C语言答案,数据结构(C语言版)习题解答(DOC).docx

1.3设n是正整数。试写出下列程序段中用记号“△”标注的语句的频度:

(2)i=1; k=0;

do {

△ k+=10*i; i++;

}while(iv=n-1)

当n=1时,执行1; 当n>=2时,执行n-1次;

(3)i=1; k=0;

do {

△ k+ = 10*i; i++; }while(i==n);

当n=2时,执行2次;

当n!=2时,执行1次;

⑷i=1; j=0;

while(i+j < n) {

△ if(i

}

执行n次;

(5) x=n; y=0; //n是不小于1的常数

while(x>=(y+1)*(y+1)){

△ y++;

}

执行(向下取整)

⑹x=91; y=100;

while ( y>0 )

△ if(x>100) { x-=10; y--; } else x++ ;

}

If语句执行100次 (7) for( i=0; ivn; i++)

for( j=i; jvn; j++)

for( k=j; kvn; k++)

△ x+=2;

过程:去丄(n _j) J(n +1)(n+2)

7 ji

第二章

2.3已知顺序表La中数据元素按非递减有序排列。试写一个算法,将元素 到La的合适位置上,保持该表的有序性。

思路:先判断线性表的存储空间是否满,若满返回Error ;否则从后向前先移动

数据,找到合适的位置插入。

Status Insert_SqList(SqList &La,int x)// 把x 插入递增有序表 La 中

{

if(La.le ngth==La.listsize) return ERROR;

for(i=La.le ngth-1;La.elem[i]>x&&i>=0;i--)

La.elem[i+1]=La.elem[i];

La.elem[i+1]=x;

La.le ngth++;

return OK;

}//l nsert_SqList

2.5试写一个算法,实现顺序表的就地逆置,即在原表的存储空间将线性表

(a1,a 2, ..., an-1, a n)逆置为(a n,a n-1 ,..., a 2,a 1)

//思路就是两个指示变量i,j同时分别从顺序表的开始和结尾处相向改变

void reverse(SqList &A)//顺序表的就地逆置

{

ElemT ype p;

for(i=1,j=A.le ngth;ivj;i++,j--)

//A.elem[i]A.elem[j];

p=A.elem[i];

A.elem[i[=A.elem[j];

A.elem[j]=p;

}//reverse

2.7已知线性表L采用顺序存储结构存放,对两种不同情况分别写出算法,删除 L中多余的元素,使得L中没有重复元素:(1)L中数据元素无序排列;(2)L中 数据元素非递减有序排列。

void Delete_SameElem(SqL ink &L,

int L.le ngth){

//内层循环移动参数,中层循环寻找相同元,外层循环遍历整个表

int i=0; int j=i+1; intlen gth=L.le ngth;

while (i

for (j=i+1;j

if (L.EIem[j]==L.EIem[i]){

for (k=j; k

L.Elem[k]=L.Elem[k+1]; len gth--;

//

j--;// 移动元素后,由于少了一个元素,因此要减 1

}

} //end if

lf(L.EIem[j]>L.EIem[i]) break;//

第二小问添加此句

} //end for

} //end while

} //end functoion

2.8已知线性表L采用链式结构存放。对两种不同情况分别写出算法,删除 L中 值相同的多余元素,使得L中没有重复元素:(1)L中数据元素无序排列;(2)L 中数据元素非递减有序排列。

(1) L中数据元素无序排列;

思路:由于是无序排列,需要线性表中每个元素都要相互进行比较。

Status ListDelete ( Linklist &L )//L 是带头结点的线性表

{

ElemT ype *p ,*q;

p==L->next;q=p->next; // 设定 p变化较慢,q变化较快

while( p->n ext){

while(q) {

if(p->data匸q->data)

q=q->n ext;

else{

q=q->n ext;

p->n ext=q;

}//else

}//while

p=p->next;q=p->next;//开始后一结点的寻找

return

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值