例2-2;已知線性表LA和B中的數(shù)據(jù)元素按值非遞減有序排列,現(xiàn)要求將LA和LB歸并為一個新的線性表LC且LC中的數(shù)據(jù)元素仍按值非遞減有序排列例如
LA=(3,5,8,11)
LB=(2,6,8,9,11,15,20)
則Lc(2,3,5,6,8,8,9,11,11,15,20)
//代碼如下
#include
#include
#define MAXSIZE 50
typedef struct l
{
?int data[MAXSIZE];
?int length;//順序表中當(dāng)前的有效元素
?
}sqlist;
//初始化
void initlist(sqlist*l)
{
?
?int i;
?for (i=0;i
??? ?l->data[i]=0;
??? ?
?}
?l->length=0;
??? ?
}
sqlist* creatlist(sqlist*l)
{
?
?int i,val;
?printf("請輸入數(shù)據(jù)\n");
?printf("請輸入數(shù)字,若輸入下一個數(shù)字則輸入空格,輸入-1時停止\n");
?scanf("%d",&val);
??? ?for (i=0;i
??? ??? ?if(val!=-1)
??? ??? ?{
??? ??? ?
??? ??? ?l->data[i]=val;
??? ??? ?l->length++;
??? ??? ?scanf("%d",&val);
??? ??? ?
??? ??? ?}
??? ?}?? ??? ?
?return l;
}
void output(sqlist*l)
{
?
?int i;
?for (i=0;i
?{
??? ?printf("%d\t",l->data[i]);
??? ?
?}
?printf("\n");?? ?
}
void mergelist(sqlist *l1,sqlist*l2,sqlist*l3)
{
?
int i,j;
int m;
i=0;
j=0;
int k=0;
m=0;
for(k=0;k
{
while (l1->data[i]==l2->data[j]&&j
{
?
?l3->data[m]=l1->data[i];
?l3->data[m+1]=l2->data[j];
?l3->length = l3->length+2;
?
?m=m+2;
?i++;
?j++;
?
?
}
?
while (l1->data[i]
?{
?
??? l3->data[m]=l1->data[i];
??? i++;
??? m++;
??? l3->length++;
?? ??? ?
?}
?
?while (l1->data[i]>l2->data[j]&&j
?{
??? ?
??? ?l3->data[m]=l2->data[j];
??? ?j++;
??? ?m++;
??? ?l3->length++;
?
?}
?
?while(i>=l1->length&&j
?{
??? ?
??? ?l3->data[m]=l2->data[j];
??? ?m++;
??? ?l3->length++;
??? ?j++;
?}
}
??? ?
}
int main()
{
?
?sqlist l1;
?sqlist l2;
?sqlist l3;
?initlist(&l1);
?initlist(&l2);
?initlist(&l3);
?creatlist(&l1);
?creatlist(&l2);
?output (&l1);
?output(&l2);
mergelist(&l1,&l2,&l3);
output(&l3);?
}
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級服務(wù)器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧
網(wǎng)站名稱:順序表合并c語言-創(chuàng)新互聯(lián)
網(wǎng)站地址:http://chinadenli.net/article36/dgjgpg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、品牌網(wǎng)站設(shè)計、面包屑導(dǎo)航、微信公眾號、網(wǎng)站排名、網(wǎng)站設(shè)計公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容