版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> *******大學(xué)</b></p><p> 《數(shù)據(jù)結(jié)構(gòu)與算法分析》課程設(shè)計(jì)</p><p> 題 目:數(shù)據(jù)結(jié)構(gòu)上機(jī)試題</p><p><b> 學(xué)生姓名: </b></p><p><b> 學(xué) 號(hào):</b></p&g
2、t;<p> 專(zhuān) 業(yè):信息管理與信息系統(tǒng)</p><p><b> 班 級(jí):</b></p><p><b> 指導(dǎo)教師: </b></p><p><b> 2014年04月</b></p><p><b> 目錄</b&g
3、t;</p><p> 一、順序表的操作2</p><p> 【插入操作原理】2</p><p> 【刪除操作原理】2</p><p> 【NO.1代碼】3</p><p> 【運(yùn)行截圖演示】7</p><p> 二、單鏈表的操作10</p><p&g
4、t; 【創(chuàng)建操作原理】10</p><p> 【插入操作原理】10</p><p> 【刪除操作原理】10</p><p> 【NO.2代碼】11</p><p> 【運(yùn)行截圖演示】20</p><p> 三、順序棧的操作25</p><p> 【數(shù)值轉(zhuǎn)換原理】25&
5、lt;/p><p> 【NO.3代碼】26</p><p> 【運(yùn)行截圖演示】30</p><p><b> 四、查找算法32</b></p><p> 【順序查找原理】32</p><p> 【折半查找原理】32</p><p> 【NO.4代碼】33
6、</p><p> 【運(yùn)行截圖演示】38</p><p><b> 五、排序算法40</b></p><p> 【直接插入排序原理】40</p><p> 【快速排序原理】40</p><p> 【NO.5代碼】41</p><p> 【運(yùn)行截圖演示】
7、46</p><p><b> 一、順序表的操作</b></p><p> (1)插入元素操作:將新元素x插入到順序表a中第i個(gè)位置;</p><p> ?。?)刪除元素操作:刪除順序表a中第i個(gè)元素。</p><p><b> 【插入操作原理】</b></p><p&g
8、t; 線性表的插入操作是指在線性表的第i-1個(gè)數(shù)據(jù)元素和第i個(gè)數(shù)據(jù)元素之間插入一個(gè)新的數(shù)據(jù)元素,就是要是長(zhǎng)度為n的線性表:</p><p> 變成長(zhǎng)度為n+1的線性表:</p><p> 數(shù)據(jù)元素和之間的邏輯關(guān)系發(fā)生了變化。</p><p> ?。ㄆ洹静迦朐怼吭谡n本P23的算法2.3有解釋?zhuān)?lt;/p><p><b> 【刪
9、除操作原理】</b></p><p> 反之,線性表的刪除操作是使長(zhǎng)度為n的線性表:</p><p> 變成長(zhǎng)度為n-1的線性表:</p><p> 數(shù)據(jù)元素、和之間的邏輯關(guān)系發(fā)生變化,為了在存儲(chǔ)結(jié)構(gòu)上放映這個(gè)變化,同樣需要移動(dòng)元素。</p><p> ?。ㄆ洹緞h除原理】在課本P24的算法2.4有解釋?zhuān)?lt;/p>
10、<p><b> 【NO.1代碼】</b></p><p> #include<stdio.h></p><p> #define MAX 100</p><p> typedef int datatype;</p><p> typedef struct</p><
11、p><b> {</b></p><p> datatype data[MAX];</p><p><b> int list;</b></p><p><b> } </b></p><p> sequenlist; /*
12、順序表*/</p><p> int main()</p><p><b> {</b></p><p> int insert( sequenlist *L, int x, int i );</p><p> int deletee( sequenlist *L, int i );</p><
13、;p> int input( sequenlist *L );</p><p> int output( sequenlist *L );</p><p> sequenlist s,*p=&s;</p><p> int indata,inlocate,deletedx;</p><p><b> inpu
14、t(p);</b></p><p> printf( "請(qǐng)輸入要插入的數(shù):" ); </p><p> scanf( "%d",&indata );</p><p> printf( "請(qǐng)輸入要插入的位置:" );</p><p> sc
15、anf( "%d",&inlocate );</p><p> insert( p,indata,inlocate );</p><p> printf( "插入后的數(shù)據(jù):" );</p><p> output(p);</p><p> printf( "請(qǐng)輸入要?jiǎng)h除的位置:
16、" );</p><p> scanf( "%d",&deletedx );</p><p> deletee( p, deletedx );</p><p> printf( "刪除后的數(shù)據(jù):" );</p><p> output(p);</p><p&
17、gt;<b> return 0;</b></p><p><b> }</b></p><p> int output( sequenlist *L ) </p><p><b> {</b></p><p><b> int i;<
18、/b></p><p> for( i=0; i<=L->list; i++ ) </p><p> printf( "%d ",L->data[i] );</p><p> printf( "\n\n" );</p><p> return(1);</p>
19、<p><b> }</b></p><p> int input( sequenlist *L ) </p><p><b> {</b></p><p><b> int i;</b></p><p> printf
20、( "請(qǐng)輸入原始數(shù)據(jù)個(gè)數(shù):" );</p><p> scanf( "%d",&( L->list ) );</p><p> L->list--; </p><p> printf( "請(qǐng)輸入原始數(shù)據(jù):" );</p><p> for( i=0; i
21、<= L->list; i++ ) </p><p> scanf( "%d",&( L->data[i] ) );</p><p> printf( "原始數(shù)據(jù)為:" );</p><p> output(L);</p><p> return (1);</p&
22、gt;<p><b> }</b></p><p> int insert( sequenlist *L, int x, int i )</p><p><b> { </b></p><p><b> int j;</b></p><p> if (
23、( (*L).list )>=MAX-1 )</p><p><b> {</b></p><p> printf( "overflow" ); return 0;</p><p><b> }</b></p><p><b> else</b>
24、;</p><p><b> {</b></p><p> if ( (i<1) || (i> ( (*L).list )+1 ) )</p><p><b> {</b></p><p> printf( "error\n" ); </p>&
25、lt;p> return 0;}</p><p><b> else </b></p><p><b> {</b></p><p> for ( j=L->list;j>=i-1;j-- )</p><p> L->data[j+1]=L->data[j];
26、L->data[i-1]=x; L->list++;</p><p><b> }</b></p><p><b> }</b></p><p> return(1);</p><p><b> }</b></p><p> int
27、 deletee( sequenlist *L,int i ) /*定義刪除函數(shù)*/</p><p><b> { </b></p><p><b> int j;</b></p><p> if ( (i<1) || ( i>(L->list)+1 ) )</p><p
28、><b> { </b></p><p> printf( "error\n" );</p><p><b> return 0;</b></p><p><b> } </b></p><p><b> else</b&g
29、t;</p><p><b> { </b></p><p> for ( j=i;j<=L->list;j++ )</p><p> L->data[j-1]=L->data[j];</p><p> L->list--;</p><p><b>
30、 }</b></p><p> return(1);</p><p><b> }</b></p><p><b> 【運(yùn)行截圖演示】</b></p><p> ?、?、如下面的運(yùn)行截圖所示,當(dāng)輸入的線性表長(zhǎng)度設(shè)置為12的時(shí)候,該線性表最多能輸入12位數(shù)的長(zhǎng)度。</p>
31、<p> 輸入要插入的數(shù)和插入數(shù)的位置下標(biāo),便可以進(jìn)行插入操作;同理當(dāng)輸入要執(zhí)行刪除操作數(shù)的位置下標(biāo),可以將該數(shù)刪除出線性表。</p><p> ②、如下面的運(yùn)行截圖所示,當(dāng)初始設(shè)置的線性表長(zhǎng)度為5的時(shí)候,其5個(gè)數(shù)分別是-3、4、5、0、1。</p><p> 若是要執(zhí)行程序中輸入的插入數(shù)字“2”,其插入數(shù)的位置在“-4”的時(shí)候,程序是不能執(zhí)行插入操作的。此時(shí)的線性表能
32、插入的下標(biāo)范圍為“1——5”,明顯“-4”數(shù)值<下限“1”數(shù)值,所以程序執(zhí)行“error”。</p><p> ?、邸⑷缦旅娴倪\(yùn)行截圖所示,同理該線性表要插入數(shù)的位置“6”數(shù)值>上限“5”數(shù)值,所以程序執(zhí)行“error”。</p><p> ?、?、如下面的運(yùn)行截圖所示,初始設(shè)置的線性表插入數(shù)字2之后,要?jiǎng)h除位置7已超過(guò)線性表的最大長(zhǎng)度n=6,所以程序執(zhí)行“error”。<
33、/p><p> ?、?、如下面的運(yùn)行截圖所示,同理該線性表要?jiǎng)h除數(shù)的位置“0”下標(biāo)不存在,所以程序執(zhí)行“error”。</p><p><b> 二、單鏈表的操作</b></p><p> (1)創(chuàng)建一個(gè)帶頭結(jié)點(diǎn)的單鏈表;</p><p> (2)插入元素操作:將新元素x插入到單鏈表中第i個(gè)元素之后;</p>
34、<p> ?。?)刪除元素操作:刪除單鏈表中值為x的元素。 </p><p><b> 【創(chuàng)建操作原理】</b></p><p> 在單鏈表的第一個(gè)結(jié)點(diǎn)之前附設(shè)一個(gè)結(jié)點(diǎn),稱(chēng)之為頭結(jié)點(diǎn)。頭結(jié)點(diǎn)的數(shù)據(jù)域可以不存儲(chǔ)任何信息,也可以存儲(chǔ)線性表的長(zhǎng)度等的附加信息,頭結(jié)點(diǎn)的指針域存儲(chǔ)指向第一個(gè)結(jié)點(diǎn)的指針(即第一個(gè)元素結(jié)點(diǎn)的存儲(chǔ)位置)。</p>&l
35、t;p><b> 【插入操作原理】</b></p><p> 為插入數(shù)據(jù)元素x,首先要生成一個(gè)數(shù)據(jù)域?yàn)閤的結(jié)點(diǎn),然后插入在單鏈表中。根據(jù)插入操作的邏輯定義,還需要修改結(jié)點(diǎn)a中的指針域,令其指向結(jié)點(diǎn)x,而結(jié)點(diǎn)x中的指針域應(yīng)指向結(jié)點(diǎn)b,從而實(shí)現(xiàn)3個(gè)元素a、b和x之間邏輯關(guān)系的變化。</p><p> 假設(shè)s為指向結(jié)點(diǎn)x的指針,則上述指針修改用語(yǔ)描述即為:<
36、;/p><p><b> 【刪除操作原理】</b></p><p> 反之,在線性表中刪除元素b時(shí),為在單鏈表中實(shí)現(xiàn)元素a、b和c之間邏輯關(guān)系的變化,僅需要修改結(jié)點(diǎn)a中的指針域即可。</p><p> 假設(shè)p為指向結(jié)點(diǎn)a的指針,則上述指針修改用語(yǔ)描述即為:</p><p><b> 【NO.2代碼】<
37、/b></p><p> #include<stdio.h></p><p> #include<malloc.h></p><p> typedef struct node //定義鏈表</p><p><b> { </b></p><p><b&g
38、t; int data;</b></p><p> struct node *next;</p><p><b> }</b></p><p><b> snode;</b></p><p> snode* creat() //創(chuàng)建鏈表的函數(shù)</p><p&
39、gt;<b> { </b></p><p> snode *head, *p, *q;</p><p> head = (snode *)malloc(sizeof(snode));</p><p><b> p = head;</b></p><p><b> int x;&
40、lt;/b></p><p> printf("請(qǐng)輸入創(chuàng)建鏈表的值,用“0”結(jié)束輸入。\n");</p><p> printf("x = ");</p><p> scanf("%d", &x);</p><p> while (x != 0)</p&g
41、t;<p><b> {</b></p><p> q = (snode *)malloc(sizeof(snode));</p><p> q->data = x;</p><p> p->next = q;</p><p><b> p = q;</b><
42、;/p><p> printf("x = ");</p><p> scanf("%d", &x);</p><p><b> }</b></p><p> p->next = NULL; </p><p> return head;
43、</p><p><b> }</b></p><p> int length(snode *head)//測(cè)鏈表的結(jié)點(diǎn)數(shù)</p><p><b> {</b></p><p> int i = 0;</p><p> snode *p = head->nex
44、t;</p><p> while (p != NULL)</p><p><b> {</b></p><p> p = p->next;</p><p><b> i++;</b></p><p><b> } </b></p
45、><p><b> return i;</b></p><p><b> }</b></p><p> void display(snode *head) </p><p><b> {</b></p><p> snode *p = head-&
46、gt;next;</p><p> for(int i = 0; i < length(head); i++)</p><p><b> {</b></p><p> printf("%4d", p->data);</p><p> p = p->next;</p>
47、;<p><b> }</b></p><p> printf(" ");</p><p><b> }</b></p><p> int locate(snode *head, int x) </p><p><b> {</b>&
48、lt;/p><p> snode *p = head->next;</p><p> int i = 1;</p><p> while (p != NULL && x != p->data)</p><p><b> {</b></p><p> p = p-&
49、gt;next;</p><p><b> i++;</b></p><p><b> }</b></p><p> if (p == NULL) </p><p><b> return 0;</b></p><p><b>
50、 else </b></p><p><b> return i;</b></p><p><b> }</b></p><p> int insnode(snode *head, int x, int i) //把x插入到鏈表的第i的位置</p><p><b>
51、; { </b></p><p><b> int j;</b></p><p> snode *p = head->next, *s;</p><p> if(i < 1 || i > (length(head) + 1))</p><p><b> retu
52、rn 0;</b></p><p> else if (i == 1)</p><p><b> { </b></p><p> s = (snode *)malloc(sizeof(snode)); </p><p> s->next = p; </p><p&
53、gt; head->next = s; </p><p> s->data = x;</p><p><b> }</b></p><p><b> else</b></p><p><b> { </b></p><p>
54、 for (j = 1; j < i - 1; j++) </p><p> p = p->next;</p><p> s = (snode *)malloc(sizeof(snode));</p><p> s->next = p->next;</p><p> p->next = s;</
55、p><p> s->data = x; </p><p><b> }</b></p><p><b> return 1;</b></p><p><b> }</b></p><p> int delnode(snode *head, i
56、nt i)//刪除鏈表中第i個(gè)結(jié)點(diǎn)</p><p><b> {</b></p><p> snode *p = head->next, *q = head;</p><p> if(i < 1 || i > length(head))</p><p><b> return 0;&l
57、t;/b></p><p> else if (i == 1)</p><p><b> { </b></p><p> head->next = p->next;</p><p><b> free(p);</b></p><p><b&g
58、t; } </b></p><p><b> else</b></p><p><b> { </b></p><p> for (int j = 1; j < i; j++)</p><p><b> {</b></p>
59、<p> p = p->next; q = q->next;</p><p><b> }</b></p><p> q->next = p->next;</p><p> free(p); </p><p><b> }</b></p&g
60、t;<p><b> return 1;</b></p><p><b> }</b></p><p> void sort(snode *head) //把鏈表中每個(gè)結(jié)點(diǎn)的值按從小到大排列</p><p><b> {</b></p><p> sno
61、de *p, *q;</p><p><b> int k;</b></p><p> for(p = head->next; p != NULL; p = p->next)</p><p> for(q = p->next; q != NULL; q = q->next)</p><p>
62、 if (p->data > q->data)</p><p><b> { </b></p><p> k = p->data; </p><p> p->data = q->data; </p><p> q->data = k; <
63、;/p><p><b> }</b></p><p><b> }</b></p><p> void insert(snode *head, int x) //在有序鏈表中插入x,插入后仍保持有序</p><p><b> { </b></p><
64、;p> snode *p = head->next, *s, *q = head;</p><p> while (p != NULL && p->data < x)</p><p><b> { </b></p><p> q = q->next;</p><
65、;p> p = p->next;</p><p><b> }</b></p><p> s = (snode *)malloc(sizeof(snode));</p><p> s->next = q->next; </p><p> s->data = x; <
66、;/p><p> q->next = s;</p><p><b> }</b></p><p> void del_min_max(snode *head, int min, int max) //刪除有序鏈表中值min到值max中的結(jié)點(diǎn)</p><p><b> {</b></p
67、><p> snode *p = head->next, *q = head;</p><p> while (p != NULL && p->data <= min)</p><p><b> {</b></p><p><b> q = p;</b><
68、/p><p> p = p->next; </p><p><b> }</b></p><p> while (p != NULL && p->data < max)</p><p><b> { </b></p><p> q-
69、>next = p->next;</p><p><b> free(p);</b></p><p> p = q->next;</p><p><b> }</b></p><p><b> }</b></p><p> v
70、oid del_min(snode *head) </p><p><b> {</b></p><p> snode *p = head->next, *q = head;</p><p> snode *p_min, *q_min;</p><p> p_min = p;</p><
71、p> q_min = q;</p><p> while (p != NULL)</p><p><b> {</b></p><p> q = p; p = p->next;</p><p> if (p != NULL && p->data < p_min->
72、;data)</p><p><b> {</b></p><p> q_min = p_min;</p><p> p_min = p;</p><p><b> }</b></p><p><b> }</b></p><
73、;p> q_min->next = p_min->next;</p><p> free(p_min);</p><p><b> }</b></p><p> int main()</p><p><b> { </b></p><p>
74、 int min, max;</p><p> snode *headl = creat(); //創(chuàng)建鏈表</p><p> printf("最初的鏈表如下:");</p><p> display(headl);</p><p> printf("\n\n");</p><
75、;p> int num, location;</p><p> printf("請(qǐng)輸入您要查找的數(shù):");</p><p> scanf("%d", &num);</p><p> if (locate(headl, num))</p><p> printf("數(shù)字%
76、d在鏈表中的位置為:%d\n\n", num, locate(headl, num));</p><p><b> else</b></p><p> printf("數(shù)字%d在鏈表中不存在!\n\n", num);</p><p> printf("請(qǐng)分別輸入您要插入到鏈表中的數(shù)以及想插入的位置(
77、用空格號(hào)間隔開(kāi)):");</p><p> scanf("%d %d", &num, &location);</p><p> if (insnode(headl, num, location))</p><p><b> { </b></p><p> p
78、rintf("插入新值以后的鏈表如下:");</p><p> display(headl);</p><p> printf("\n\n");</p><p><b> } </b></p><p> else printf("輸入有誤!\n\n"
79、;);</p><p> printf("請(qǐng)輸入您想刪除的結(jié)點(diǎn)位置:");</p><p> scanf("%d", &location);</p><p> if (delnode(headl, location))</p><p><b> { </b>
80、;</p><p> printf("刪除第%d個(gè)結(jié)點(diǎn)后的鏈表如下:", location);</p><p> display(headl);</p><p> printf("\n\n");</p><p><b> } </b></p><p
81、><b> else</b></p><p> printf("輸入有誤! \n\n");</p><p><b> }</b></p><p><b> 【運(yùn)行截圖演示】</b></p><p> ①、如下面的運(yùn)行截圖所示,創(chuàng)建帶有頭結(jié)點(diǎn)且
82、長(zhǎng)度為8的單鏈表:4、8、2、-4、-6、1、9、-1。</p><p> 輸入要查詢(xún)的數(shù)“-6”,則查詢(xún)到單鏈表中數(shù)“-6”的存儲(chǔ)位置為“5”的下標(biāo)號(hào)。</p><p> 輸入要插入的數(shù)和插入數(shù)的位置下標(biāo),便可以進(jìn)行插入操作。程序中要求插入的數(shù)是“3”,插入數(shù)的位置下標(biāo)為“5”,兩者之間用空格號(hào)隔開(kāi),則插入后的新單鏈表為:4、8、2、-4、3、-6、1、9、-1。</p>
83、<p> 同理當(dāng)輸入要執(zhí)行刪除操作的數(shù)位置下標(biāo),可以對(duì)該數(shù)刪除出線性表。程序中要求刪除的數(shù)下標(biāo)是7,則執(zhí)行該刪除操作之后的新單鏈表為:4、8、2、-4、3、-6、9、-1。</p><p> ?、?、如下面的運(yùn)行截圖所示,創(chuàng)建帶有頭結(jié)點(diǎn)且長(zhǎng)度為8的單鏈表,要查詢(xún)的數(shù)“3”不在該單鏈表中,所以程序執(zhí)行“error”。</p><p> ?、邸⑷缦旅娴倪\(yùn)行截圖所示,創(chuàng)建帶頭結(jié)點(diǎn)且
84、長(zhǎng)度為8的單鏈表,要插入數(shù)的位置下標(biāo)“-1”不在該單鏈表中,所以程序執(zhí)行“error”。</p><p> ?、?、如下面的運(yùn)行截圖所示,創(chuàng)建帶頭結(jié)點(diǎn)且長(zhǎng)度為8的單鏈表,要插入的位置下標(biāo)“9”為單鏈表最大長(zhǎng)度,所以程序執(zhí)行插入操作。</p><p> ⑤、如下面的運(yùn)行截圖所示,創(chuàng)建帶頭結(jié)點(diǎn)且長(zhǎng)度為8的單鏈表,要插入的位置下標(biāo)“10”超出單鏈表長(zhǎng)度,所以程序不執(zhí)行插入操作。</p>
85、;<p> ?、?、如下面的運(yùn)行截圖所示,創(chuàng)建帶頭結(jié)點(diǎn)且長(zhǎng)度為8的單鏈表,要?jiǎng)h除數(shù)的位置下標(biāo)“-2”不在該單鏈表中,所以程序執(zhí)行“error”。</p><p> ?、摺⑷缦旅娴倪\(yùn)行截圖所示,創(chuàng)建帶頭結(jié)點(diǎn)且長(zhǎng)度為8的單鏈表,要?jiǎng)h除數(shù)的位置下標(biāo)“10”超出單鏈表長(zhǎng)度,所以程序執(zhí)行“error”。</p><p><b> 三、順序棧的操作</b></
86、p><p> 在順序棧上實(shí)現(xiàn)將非負(fù)十進(jìn)制數(shù)轉(zhuǎn)換成二進(jìn)制數(shù)。</p><p><b> 【數(shù)值轉(zhuǎn)換原理】</b></p><p> 十進(jìn)制數(shù)N和其他d進(jìn)制數(shù)的轉(zhuǎn)換時(shí)計(jì)算機(jī)實(shí)現(xiàn)計(jì)算的基本問(wèn)題,其解決方法很多,其中一個(gè)簡(jiǎn)單算法基于下列原理:</p><p> (其中:div為整除運(yùn)算,mod為求余運(yùn)算)</p>
87、<p> 假設(shè)現(xiàn)在要編制一個(gè)滿足下列要求的程序:對(duì)于輸入的任意一個(gè)非負(fù)十進(jìn)制整數(shù),打印輸出與其等值的二進(jìn)制數(shù)。</p><p> 由于上述計(jì)算過(guò)程是從低位到高位順序產(chǎn)生二進(jìn)制數(shù)的各個(gè)數(shù)位,而打印輸出,一般來(lái)說(shuō)應(yīng)從高位到低位進(jìn)行,恰好和計(jì)算過(guò)程相反。因此,若將計(jì)算過(guò)程中得到的二進(jìn)制數(shù)的各位順序進(jìn)棧,則按出棧序列打印輸出的即為輸入對(duì)應(yīng)的二進(jìn)制數(shù)。</p><p> ?。ㄆ洹緮?shù)
88、值轉(zhuǎn)換】在課本P48的算法3.2有解釋?zhuān)?lt;/p><p><b> 【NO.3代碼】</b></p><p> #include <stdio.h></p><p> #include <stdlib.h></p><p> #define MaxSize 50</p>&l
89、t;p> typedef char ElemType;</p><p> char digit[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";</p><p> typedef struct</p><p><b> {</b></p><p>
90、 ElemType data[MaxSize];</p><p><b> int top;</b></p><p><b> }</b></p><p><b> SqStack;</b></p><p> void InitStack(SqStack *&s
91、)</p><p><b> {</b></p><p> s = (SqStack *)malloc(sizeof(SqStack));</p><p> s -> top = -1;</p><p><b> }</b></p><p> int Push
92、(SqStack *&s, ElemType e)</p><p><b> {</b></p><p> if(s -> top == MaxSize - 1)</p><p><b> return 0;</b></p><p> s -> top++;</p&
93、gt;<p> s -> data[s -> top] = e;</p><p><b> return 1;</b></p><p><b> }</b></p><p> int Pop(SqStack *&s, ElemType &e)</p><
94、p><b> {</b></p><p> if(s -> top == -1)</p><p><b> return 0;</b></p><p> e = s -> data[s -> top];</p><p> s -> top--;return
95、1;</p><p><b> }</b></p><p> int GetTop(SqStack *s, ElemType &e)</p><p><b> {</b></p><p> if(s -> top == -1)</p><p><
96、b> return 0;</b></p><p> e = s -> data[s -> top];</p><p><b> return 1;</b></p><p><b> }</b></p><p> void DispStack(SqStack *
97、s)</p><p><b> { </b></p><p><b> int i;</b></p><p> for(i = s -> top; i >= 0; i--) </p><p> printf("%c", s -> data[i]);&
98、lt;/p><p> printf("\n");</p><p><b> }</b></p><p> int fun(SqStack *s,int num, int k) //可將十進(jìn)制轉(zhuǎn)換成任意進(jìn)制</p><p><b> {</b></p><p
99、> static int count = 0;</p><p><b> int n;</b></p><p> if(num < k)</p><p><b> {</b></p><p> Push(s, digit[num]);</p><p>
100、 return count;</p><p><b> }</b></p><p> n = num % k;</p><p> Push(s, digit[n]);</p><p> fun(s,num/k, k);</p><p><b> }</b></
101、p><p> int main()</p><p><b> {</b></p><p> SqStack *t;</p><p><b> int i;</b></p><p> InitStack(t);</p><p> printf(&
102、quot;請(qǐng)輸入一個(gè)非負(fù)十進(jìn)制數(shù):");</p><p> scanf("%d", &i);</p><p> fun(t, i, 2); </p><p> printf("其二進(jìn)制數(shù)為:");</p><p> DispStack(t);</p><p
103、><b> free(t);</b></p><p><b> return 0;</b></p><p><b> }</b></p><p><b> 【運(yùn)行截圖演示】</b></p><p> ①、如下面的運(yùn)行截圖所示,輸入非負(fù)十進(jìn)制
104、整數(shù)“14”,經(jīng)過(guò)數(shù)值轉(zhuǎn)換之后的二進(jìn)制數(shù)為“1110”。</p><p> ?、?、如下面的運(yùn)行截圖所示,輸入十進(jìn)制整數(shù)“-2”,由于“-2”為負(fù)數(shù),所以無(wú)法經(jīng)過(guò)數(shù)值轉(zhuǎn)換為二進(jìn)制數(shù)。</p><p> ?、?、如下面的運(yùn)行截圖所示,輸入非負(fù)十進(jìn)制整數(shù)“0”,經(jīng)過(guò)數(shù)值轉(zhuǎn)換之后的二進(jìn)制數(shù)為“0”。</p><p><b> 四、查找算法</b><
105、;/p><p> 在順序表中采用順序查找算法和折半查找算法尋找關(guān)鍵字X在順序表中的位置。</p><p><b> 【順序查找原理】</b></p><p> 從表中最后一個(gè)記錄開(kāi)始,逐個(gè)進(jìn)行記錄的關(guān)鍵字和給定值的比較,若某個(gè)記錄的關(guān)鍵字和給定值比較相等,則查找成功,找到所查記錄;反之,若直至第一個(gè)記錄,其關(guān)鍵字和給定值比較都不等,則表明表中
106、沒(méi)有所查記錄,查找不成功。</p><p> 在等概率情況下順序查找的平均長(zhǎng)度為:</p><p><b> 【折半查找原理】</b></p><p> 先確定待查記錄所在的范圍(區(qū)間),然后逐步縮小范圍直到找到或找不到該記錄為止。</p><p> 折半查找過(guò)程是以處于區(qū)間中間位置記錄的關(guān)鍵字和給定值比較,若相
107、等,則查找成功,若不等,則縮小范圍,直至新的區(qū)間中間位置記錄的關(guān)鍵字等于給定值或者查找區(qū)間的大小小于零時(shí)(表明查找不成功)為止。</p><p> 假設(shè)表中每個(gè)記錄的查找概率相等,則查找成功時(shí)折半查找的平均查找長(zhǎng)度:</p><p><b> 【NO.4代碼】</b></p><p> #include <stdio.h>&l
108、t;/p><p> #include <math.h></p><p> #define MAXL 1000</p><p> #define INF 32767</p><p> int process[MAXL],pn;</p><p> //順序表的存儲(chǔ)結(jié)構(gòu)</p><p&g
109、t; typedef int KeyType;</p><p> typedef int InfoType;</p><p> typedef struct</p><p><b> { </b></p><p> KeyType key;</p><p> InfoType d
110、ata;</p><p><b> } </b></p><p><b> NodeType;</b></p><p> typedef NodeType SeqList[MAXL];</p><p> //索引表的存儲(chǔ)結(jié)構(gòu)</p><p> typedef str
111、uct</p><p><b> { </b></p><p> KeyType key;</p><p><b> int link;</b></p><p><b> } </b></p><p><b> IdxType;
112、</b></p><p> typedef IdxType IDX[MAXL];</p><p><b> //順序查找算法</b></p><p> int SeqSearch(SeqList R,int n,KeyType k)</p><p><b> {</b></
113、p><p><b> int i=0;</b></p><p><b> pn=0;</b></p><p> while(i<n&&R[i].key!=k)</p><p><b> { </b></p><p>
114、process[pn++]=R[i].key;</p><p><b> i++;</b></p><p><b> } </b></p><p> if(i>=n) return -1;</p><p> else return i;</p><p>&l
115、t;b> } </b></p><p><b> //折半查找算法</b></p><p> int BinSearch(SeqList R,int n,KeyType k)</p><p><b> { </b></p><p> int low=0,hig
116、h=n-1,mid;</p><p><b> pn=0;</b></p><p> while(low<=high)</p><p><b> {</b></p><p> mid=(low+high)/2;</p><p> if(R[mid].key==
117、k) return mid;</p><p> if(R[mid].key>k)</p><p><b> {</b></p><p> process[pn++]=R[mid].key;</p><p> high=mid-1;</p><p> } </p
118、><p><b> else</b></p><p> { </p><p> process[pn++]=R[mid].key;</p><p> low=mid+1;</p><p><b> } </b></p><p>
119、;<b> } </b></p><p> return -1;</p><p><b> } </b></p><p> int main()</p><p><b> { </b></p><p> int n,i,k,m;&l
120、t;/p><p> SeqList R;</p><p><b> IDX I;</b></p><p> printf("(1)請(qǐng)輸入有/無(wú)序順序表的元素個(gè)數(shù):\n");</p><p> while(scanf("%d",&n)!=EOF)</p>&
121、lt;p><b> {</b></p><p> printf("請(qǐng)輸入有/無(wú)序順序表的%d個(gè)元素:\n",n);</p><p> for(i=0;i<n;i++) </p><p> scanf("%d",&R[i].key);</p><p>
122、printf("請(qǐng)輸入要查找的關(guān)鍵字:\n");</p><p> scanf("%d",&k);</p><p> printf("使用順序查找算法,");</p><p> if(SeqSearch(R,n,k)!=-1)</p><p><b> {&
123、lt;/b></p><p> printf("關(guān)鍵字%d的下標(biāo)為:\n%d\t\n查找過(guò)程為:\n",k,SeqSearch(R,n,k));</p><p> for(i=0;i<pn;i++) printf("%d ",process[i]);</p><p> printf("%d\n\n&
124、quot;,k);</p><p><b> }</b></p><p> else printf("要查找的關(guān)鍵字%d不在無(wú)序順序表中\(zhòng)n\n",k);</p><p> printf("(2)請(qǐng)輸入有序順序表的元素個(gè)數(shù):\n");//10</p><p> scanf(
125、"%d",&n);</p><p> printf("請(qǐng)輸入有序順序表的%d個(gè)元素:\n",n);</p><p> for(i=0;i<n;i++) </p><p> scanf("%d",&R[i].key);</p><p> printf(&q
126、uot;請(qǐng)輸入要查找的關(guān)鍵字:\n");</p><p> scanf("%d",&k);</p><p> printf("使用折半查找算法,");</p><p> if(BinSearch(R,n,k)!=-1)</p><p><b> {</b>
127、</p><p> printf("關(guān)鍵字%d的下標(biāo)為:\n%d\t\n查找過(guò)程為:\n",k,BinSearch(R,n,k));</p><p> for(i=0;i<pn;i++) </p><p> printf("%d ",process[i]);</p><p> printf
128、("%d\n\n",k);</p><p><b> }</b></p><p> else printf("要查找的關(guān)鍵字%d不在有序順序表中\(zhòng)n\n",k);</p><p><b> return 0;</b></p><p><b>
129、 }</b></p><p><b> }</b></p><p><b> 【運(yùn)行截圖演示】</b></p><p> ?、佟⑷缦旅娴倪\(yùn)行截圖所示,使用順序查詢(xún)算法和折半查找算法,查找數(shù)“5”,其查找過(guò)程分別為:-3、5、8、9、-2、-1;3、-2、-1。</p><p> ?、?/p>
130、、如下面的運(yùn)行截圖所示,在無(wú)序順序表中使用順序查詢(xún)算法,查找數(shù)“6”,因數(shù)“6”位置下標(biāo)超過(guò)表最大長(zhǎng)度,即程序查找不到。</p><p> ?、?、如下面的運(yùn)行截圖所示,在無(wú)序順序表中使用順序查詢(xún)算法,查找數(shù)“1”,因?yàn)閿?shù)“1”不在該表中,所以程序查找不到數(shù)“1”。</p><p> ?、?、如下面的運(yùn)行截圖所示,在有序順序表中使用折半查詢(xún)算法,查找數(shù)“1”,因?yàn)閿?shù)“1”不在該表中,所以程序查
131、找不到數(shù)“1”。</p><p><b> 五、排序算法</b></p><p> 將無(wú)序數(shù)列使用直接插入排序算法和快速排序算法將其排成遞增有序數(shù)列。</p><p> 【直接插入排序原理】</p><p> 是一種最簡(jiǎn)單的排序方法,它的基本操作是將一個(gè)記錄插入到已排好序的有序表中,從而得到一個(gè)新的、記錄數(shù)增1的
132、有序表。</p><p> 排序的基本操作為:比較兩個(gè)關(guān)鍵字的大小和移動(dòng)記錄。先分析一趟插入排序的情況。For循環(huán)的次數(shù)取決于待插記錄的關(guān)鍵字與前i-1個(gè)記錄的關(guān)鍵字之間的關(guān)系。則在整個(gè)排序過(guò)程(進(jìn)行n-1趟插入排序)中,當(dāng)待排序列中記錄按關(guān)鍵字非遞減有序排列,所需進(jìn)行關(guān)鍵字間比較的次數(shù)達(dá)最小值n-1,記錄不需移動(dòng);反之,當(dāng)待排序列中記錄按關(guān)鍵字非遞增有序排列是,總的比較次數(shù)達(dá)到最大值,記錄移動(dòng)的次數(shù)也達(dá)最大值
133、。若待排序記錄是隨機(jī)的,即待排序列中的記錄可能出現(xiàn)的各種排列的概率相同,則我們可取上述最小值和最大值的平均值,作為直接插入排序時(shí)所需進(jìn)行關(guān)鍵字間的比較次數(shù)和移動(dòng)記錄的次數(shù)。</p><p><b> 【快速排序原理】</b></p><p> 快速排序是對(duì)起泡排序的一種改進(jìn)。它的基本思想是,通過(guò)一趟排序?qū)⒋判蛴涗浄指畛瑟?dú)立的兩部分,其中一部分記錄的關(guān)鍵字均比另一
134、部分記錄的關(guān)鍵字小,則可分別對(duì)這兩部分記錄繼續(xù)進(jìn)行排序,以達(dá)到整個(gè)序列有序。</p><p><b> 【NO.5代碼】</b></p><p> #include<iostream.h></p><p> #include<stdlib.h></p><p> #define MAX 1
135、00</p><p> //將無(wú)序數(shù)列使用直接插入排序算法和快速排序算法將其排成遞增有序數(shù)列</p><p> typedef struct </p><p><b> {</b></p><p> int data[MAX];</p><p> int length;</p>
136、;<p><b> }</b></p><p><b> sqlist;</b></p><p> void init(sqlist &a)//線性表初始化</p><p><b> {</b></p><p> a.length=0;</
137、p><p><b> }</b></p><p> void insert(sqlist &a ,int i,int x)// 插入元素,構(gòu)造無(wú)序數(shù)列</p><p><b> {</b></p><p><b> int j;</b></p><
138、;p> if(i<0||i>a.length+1||a.length==100);</p><p><b> else</b></p><p><b> {</b></p><p> for(j=a.length+1;j>i;j--)</p><p> a.data
139、[j]=a.data[j-1];</p><p> a.data[j]=x;</p><p> a.length++;</p><p><b> }</b></p><p><b> } </b></p><p> //放在a.data[n]中,被排序的記錄放在a.
140、data[0..n-1]中,直接插入排序算法。</p><p> void insertsort(sqlist &a)//直接插入排序算法</p><p><b> {</b></p><p><b> int i,j;</b></p><p> int n=a.length;<
141、;/p><p> for(i=n-2;i>=0;i--) </p><p> if(a.data[i]>a.data[i+1]) </p><p><b> { </b></p><p> a.data[n]=a.data[i];//a.data[n]是哨兵</p><p><
142、;b> j=i+1; </b></p><p><b> do</b></p><p><b> { </b></p><p> a.data[j-1]=a.data[j]; </p><p><b> j++;</b></p><
143、;p><b> }</b></p><p> while(a.data[j]<a.data[n]);</p><p> a.data[j-1]=a.data[n];</p><p><b> }</b></p><p><b> }</b></p&
144、gt;<p> int Partition(sqlist &a,int i,int j)</p><p><b> {</b></p><p> int pivot=a.data[i];</p><p> while(i<j)</p><p><b> {</b>
145、;</p><p> while(i<j&&a.data[j]>=pivot) </p><p><b> j--; </b></p><p><b> if(i<j) </b></p><p> a.data[i++]=a.data[j]; </p&
146、gt;<p> while(i<j&&a.data[i]<=pivot) </p><p><b> i++; </b></p><p><b> if(i<j) </b></p><p> a.data[j--]=a.data[i]; </p><
147、;p><b> } </b></p><p> a.data[i]=pivot; </p><p><b> return i;</b></p><p><b> }</b></p><p> void QuickSort(sqlist &a,int l
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)順序表課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)1順序表-鏈表
- 數(shù)據(jù)結(jié)構(gòu)順序表課程設(shè)計(jì)--順序表基本實(shí)現(xiàn)和存儲(chǔ)結(jié)構(gòu)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--排序算法
- 數(shù)據(jù)結(jié)構(gòu)-順序表的查找插入與刪除
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---排序算法比較
- 拓?fù)渑判?算法與數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì))
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--排序算法比較
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----內(nèi)部排序算法性能分析
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-- 循環(huán)單鏈表
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--排序算法演示系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---排序算法的實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告內(nèi)部排序的算法設(shè)計(jì)與分析
- (數(shù)據(jù)結(jié)構(gòu)c語(yǔ)言版)順序表和單鏈表的逆置
- 大數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)排序算法演示系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--內(nèi)部排序算法的性能分析
- 數(shù)據(jù)結(jié)構(gòu)與算法分析課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--內(nèi)部排序算法的比較
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--幾種排序算法的演示
- 數(shù)據(jù)結(jié)構(gòu)與算法查找
評(píng)論
0/150
提交評(píng)論