数据结构(C语言版)习题解答
onduty1.3 设n是正整数。试写出下列程序段中用记号“△”标注的语句的频度:
(2) i=1; k=0;
do {
维瓦尔第简介
△k+=10*i;
i++;
}while(i<=n-1)
当n=1时,执行1;
当n>=2时,执行n-1次;
(3) i=1; k=0;
do {
△k+ = 10*i; i++;chamillionaire
}while(i==n);
当n=2时,执行2次;
当n!=2时,执行1次;
(4) i=1; j=0;
while(i+j≤n) {
△if(i<="" p="">
}
执行n次;
(5) x=n; y=0; //n是不小于1的常数
while(x>=(y+1)*(y+1)){
△y++;
}
执行向下取整)
(6) x=91; y=100;
while ( y>0 )
△if(x>100) { x-=10; y--; }
el x++ ;
}
If语句执行100次
(7) for( i=0; i<="" p="">
for( j=i; j<="" p="">eachother
for( k=j; k<="" p="">
△x+=2;少儿英语单词游戏
byzantine过程:n1n1
i0j i
n(n1)(n2) (n j)
6
--==
++ -=
∑∑
第二章
2.3 已知顺序表La中数据元素按非递减有序排列。试写一个算法,将元素x插到La的合适位置上,保持该表的有序性。
思路:先判断线性表的存储空间是否满,若满返回Error;否则从后向前先移动数据,找到合适的位置插入。
Status Inrt_SqList(SqList &La,int x)//把x 插入递增有序表La 中
{
if(La.length==La.listsize) return ERROR;
for(i=La.length-1;La.elem[i]>x&&i>=0;i--)
La.elem[i+1]=La.elem[i];
La.elem[i+1]=x;
La.length++;
return OK;
}//Inrt_SqList
2.5 试写一个算法,实现顺序表的就地逆置,即在原表的存储空间将线性表
(a
1,a
2
, ..., a
n-1
,a
n
)逆置为(a
英语四级学习网站
n
,a
n-1
, ..., a
2
,a
1
)
//思路就是两个指示变量i,j同时分别从顺序表的开始和结尾处相向改变
void rever(SqList &A)//顺序表的就地逆置
{
ElemType p;
for(i=1,j=A.length;i<j;i++,j--)< bdsfid="140" p=""></j;i++,j--)<>挫折的事例
{
//A.elem[i]<->A.elem[j];
p=A.elem[i];
A.elem[i[=A.elem[j];
A.elem[j]=p;
}
}//rever
2.7 已知线性表L采用顺序存储结构存放,对两种不同情况分别写出算法,删除L中多余的元素,使得L中没有重复元素:(1)L中数据元素无序排列;(2)L中数据元素非递减有序排
列。
void Delete_SameElem(SqLink &L, int L.length){
//内层循环移动参数,中层循环寻找相同元,外层循环遍历整个表
int i=0; int j=i+1; int length=L.length;
while(i<length){< bdsfid="153" p=""></length){<>
for(j=i+1;j<="" p="">
if(L.Elem[j]==L.Elem[i]){//
for(k=j; k<="" p="">
L.Elem[k]=L.Elem[k+1];
length--;
j--;//移动元素后,由于少了一个元素,因此要减1
}
}//end if
doublerIf(L.Elem[j]>L.Elem[i]) break;//第二小问添加此句
}//end for
manfriday}//end while
}//end functoion
2.8 已知线性表L采用链式结构存放。对两种不同情况分别写出算法,删除L中值相同的多余元素,使得L中没有重复元素:(1)L中数据元素无序排列;(2)L 中数据元素非递减有序排列。