欧美色欧美亚洲高清在线观看,国产特黄特色a级在线视频,国产一区视频一区欧美,亚洲成a 人在线观看中文

  1. <ul id="fwlom"></ul>

    <object id="fwlom"></object>

    <span id="fwlom"></span><dfn id="fwlom"></dfn>

      <object id="fwlom"></object>

      數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告.doc(范文大全)

      時(shí)間:2019-05-14 02:01:27下載本文作者:會(huì)員上傳
      簡介:寫寫幫文庫小編為你整理了多篇相關(guān)的《數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告.doc》,但愿對(duì)你工作學(xué)習(xí)有幫助,當(dāng)然你在寫寫幫文庫還可以找到更多《數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告.doc》。

      第一篇:數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告.doc

      《數(shù)據(jù)結(jié)構(gòu)》課程實(shí)驗(yàn)報(bào)告

      專業(yè):

      指導(dǎo)老師:

      班級(jí):

      姓名:

      學(xué)號(hào):

      完成日期:

      一、實(shí)驗(yàn)?zāi)康?/p>

      1、掌握線性表的順序存儲(chǔ)結(jié)構(gòu)和鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu);

      2、熟練掌握順序表和鏈表基本算法的實(shí)現(xiàn);

      3、掌握利用線性表數(shù)據(jù)結(jié)構(gòu)解決實(shí)際問題的方法和基本技巧;

      4、按照實(shí)驗(yàn)題目要求獨(dú)立正確地完成實(shí)驗(yàn)內(nèi)容(編寫、調(diào)試算法程序,提交程序清單及及相關(guān)實(shí)驗(yàn)數(shù)據(jù)與運(yùn)行結(jié)果);

      5、按時(shí)提交實(shí)驗(yàn)報(bào)告。

      二、實(shí)驗(yàn)環(huán)境

      計(jì)算機(jī)、C語言程序設(shè)計(jì)環(huán)境

      三、實(shí)驗(yàn)學(xué)時(shí)

      2學(xué)時(shí),選做實(shí)驗(yàn)。

      四、實(shí)驗(yàn)內(nèi)容

      一、順序表的基本操作實(shí)現(xiàn)實(shí)驗(yàn)

      要求:數(shù)據(jù)元素類型ElemType取整型int。按照順序存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)如下算法(各算法邊界條件和返回結(jié)果適當(dāng)給出):

      ① 創(chuàng)建任意整數(shù)線性表(即線性表的元素值隨機(jī)在鍵盤上輸入),長度限定在20之內(nèi); ② 打印(遍歷)該線性表(依次打印出表中元素值); ③ 在線性表中查找第i個(gè)元素,并返回其值; ④ 在線性表中第i個(gè)元素之前插入一已知元素; ⑤ 在線性表中刪除第i個(gè)元素;

      ⑥ 求線性表中所有元素值(整數(shù))之和;

      二、鏈表(帶頭結(jié)點(diǎn))基本操作實(shí)驗(yàn)

      要求:數(shù)據(jù)元素類型ElemType取字符型char。按照動(dòng)態(tài)單循環(huán)鏈表結(jié)構(gòu)實(shí)現(xiàn)如下算法(各算法邊界條件適當(dāng)給出):

      ① 創(chuàng)建任意字符型有序(遞增排序)單循環(huán)鏈表(即鏈表的字符元素隨機(jī)在鍵盤上輸入),長度限定在15之內(nèi); ② 打印(遍歷)該鏈表(依次打印出表中元素值); ③ 在鏈表中查找第i個(gè)元素,i合法返回元素值,否則,返回FALSE; ④ 在鏈表中查找與一已知字符相同的第一個(gè)結(jié)點(diǎn),有則返回TRUE,否則,返回FALSE; ⑤ 在鏈表中按照有序方式插入一已知字符元素; ⑥ 在線性表中刪除第i個(gè)結(jié)點(diǎn); ⑦ 計(jì)算鏈表的長度。

      五、實(shí)驗(yàn)內(nèi)容一步驟:

      #include #include #define MAX 20 typedef int ElemType;typedef struct { ElemType elem[MAX];int last;}SeqList;void InitList(SeqList *L){ L->last=-1;} void PrintList(SeqList *L)

      { int i;

      printf(“n現(xiàn)在的數(shù)據(jù)為:”);

      for(i=0;i<=L->last;i++)

      printf(“%d ”,L->elem[i]);

      }

      void CreatList(SeqList *L){ ElemType e;int i=0;printf(“n輸入數(shù)據(jù)(-1退出):”);

      scanf(“%d”,&e);while(e!=-1){

      if(i

      {

      L->elem[i]=e;

      L->last=i;

      i++;

      }

      else

      {

      printf(“n表滿!”);

      }

      scanf(“%d”,&e);} } void Locate(SeqList *L, int i,ElemType e){ i=0;while((i<=L->last)&&(L->elem[i]!=e))

      i++;if(i<=L->last)

      printf(“n%d在順序表中第%d個(gè)位置上?!?e,i+1);else

      printf(“n沒有此數(shù)!”);} void InsList(SeqList *L, int i, ElemType e){

      int k;

      if(i<1||i>L->last+2)

      {

      printf(“n插入位置i值不合法”);

      }

      else if(L->last>=MAX-1)

      printf(“n表已滿無法插入”);

      else

      {

      for(k=L->last;k>=i-1;k--)

      L->elem[k+1]=L->elem[k];

      L->elem[i-1]=e;

      L->last++;

      }

      PrintList(L);} void DelList(SeqList *L,int i,ElemType *e){ int k;if(i<1||i>L->last+1){

      printf(“n刪除位置不合法!”);} else

      {

      *e=L->elem[i-1];

      for(k=i;k<=L->last;k++)

      L->elem[k-1]=L->elem[k];

      L->last=L->last-1;

      } PrintList(L);} void SumList(SeqList *L){ int j,sum=0;for(j=0;j<=L->last;j++){

      sum=sum+L->elem[j];} printf(“所有元素之和:%d”,sum);} void menu(){ printf(“n************************菜單*********************”);printf(“n

      1.創(chuàng)建任意整數(shù)線性表”);printf(“n

      2.打?。ū闅v)線性表”);printf(“n

      3.查找元素”);printf(“n

      4.插入元素”);printf(“n

      5.刪除元素”);printf(“n

      6.所有元素之和”);printf(“n

      7.退出”);printf(“n***********************************************”);} void main(){ int i;int flag=0;ElemType e;SeqList *L;L=(SeqList*)malloc(sizeof(SeqList));

      InitList(L);menu();while(!flag){

      printf(“nn請(qǐng)輸入你的選擇:”);

      scanf(“%d”,&i);

      switch(i)

      {

      case 1:

      CreatList(L);

      break;

      case 2:

      PrintList(L);

      break;

      case 3:

      printf(“輸入要查找的數(shù)值:”);

      scanf(“%d”,&e);

      Locate(L,i,e);

      break;

      case 4:

      printf(“輸入插入位置和數(shù)據(jù)值(a b):”);

      scanf(“%d%d”,&i,&e);

      InsList(L,i,e);

      break;

      case 5:

      printf(“輸入要?jiǎng)h除元素的位置:”);

      scanf(“%d”,&i);

      DelList(L,i,&e);

      break;

      case 6:

      SumList(L);

      break;

      case 7:

      flag=1;

      break;

      } } }

      六、實(shí)驗(yàn)內(nèi)容一測試數(shù)據(jù)與實(shí)驗(yàn)結(jié)果:

      七、實(shí)驗(yàn)內(nèi)容二步驟:

      #include #include #define MAX 15 #define TURE 1 #define FALSE 0 typedef char ElemType;typedef struct Node { char date;struct Node * next;

      }Node,*LinkList;void InitList(LinkList *L){ *L=(LinkList)malloc(sizeof(char));(*L)->next=NULL;} void PrintfLink(LinkList L)

      { LinkList p;

      p=L->next;

      printf(“鏈表為:”);while(p!=NULL)

      {

      printf(“%c ”,p->date);

      p=p->next;

      } } void Create(LinkList L){ LinkList s,r;char c;int flag=1;int n;r=L;printf(“元素個(gè)數(shù):”);scanf(“%d”,&n);if(n>MAX)

      printf(“超出限定長度!”);else {

      printf(“輸入字符(以#鍵結(jié)束):”);

      while(flag)

      {

      scanf(“%c”,&c);

      if(c!='#')

      {

      s=(Node*)malloc(sizeof(char));

      s->date=c;

      r->next=s;

      r=s;

      }

      else

      flag=0;

      r->next =NULL;

      } } } void Order(LinkList L){ char c;Node *r,*q,*p;for(r=L->next;r->next!=NULL;r=r->next){

      p=r;

      for(q=r->next;q;q=q->next)

      if((q->date)<(p->date))

      p=q;

      if(p!=r)

      {

      c=r->date;

      r->date=p->date;

      p->date=c;

      } } PrintfLink(L);

      }

      void Get(LinkList L, int i, ElemType *e){

      int j;Node *p;

      p=L;j=-1;while((p->next!=NULL)&&(j

      {

      p=p->next;

      j++;

      } *e=p->date;if(i==j)

      printf(“第%d個(gè)元素為:%c”,i,*e);

      else

      printf(“FALSE”);

      }

      void Locate(LinkList L, ElemType e){ int i=1;LinkList p;p=L->next;while(p&&p->date!=e){

      i=i++;

      p=p->next;} if(!p)

      printf(“FALSEn”);else

      {

      printf(“TRUEn”);

      printf(“該元素在第%d個(gè)位置!”,i-1);} } void InsList(LinkList L,int i,ElemType e){ Node *p,*s;

      int k=0;

      p=L;

      while(p!=NULL&&k

      {

      p=p->next;

      k=k++;

      }

      if(!p)

      {

      printf(“插入位置不合理!”);

      }

      s=(Node*)malloc(sizeof(char));

      s->date=e;

      s->next=p->next;

      p->next=s;Order(L);} void DelList(LinkList L,int i,ElemType *e){ Node *p,*r;int j;j=0;

      p=L;

      while((p->next!=NULL)&&(j

      {

      p=p->next;

      j++;

      }

      if(p->next!=NULL)

      {

      p->next=p->next->next;

      r=p->next;

      *e=r->date;

      printf(“刪除第%d個(gè)元素:%cn”,i,*e);} else

      printf(“刪除結(jié)點(diǎn)的位置i不合理!”);

      } void ListLength(LinkList L){ Node *p;int j=0;p=L->next;while(p!=NULL){

      p=p->next;

      j++;} printf(“單鏈表的長度:%d”,j);} void menu(){ printf(“n************************菜單*********************”);printf(“n

      1.創(chuàng)建任意字符型單循環(huán)鏈表”);printf(“n

      2.打印(遍歷)該鏈表”);printf(“n

      3.查找第i個(gè)元素”);printf(“n

      4.查找與一已知字符相同的元素”);printf(“n

      5.插入元素”);printf(“n

      6.刪除第i個(gè)結(jié)點(diǎn)”);printf(“n

      7.計(jì)算鏈表的長度”);printf(“n

      8.退出”);printf(“n***********************************************”);} void main(){ int i;int flag=0;ElemType e;

      LinkList L;L=(LinkList)malloc(sizeof(char));

      InitList(&L);menu();while(!flag){

      printf(“nn請(qǐng)輸入你的選擇(1~8):”);

      scanf(“%d”,&i);

      switch(i)

      {

      case 1:

      Create(L);

      break;

      case 2:

      }

      }

      Order(L);break;case 3: printf(“輸入要查找的第i個(gè)元素:”);scanf(“%d”,&i);Get(L,i,&e);break;case 4: printf(“輸入查找的元素:”);rewind(stdin);scanf(“%c”,&e);Locate(L,e);break;case 5: printf(“輸入插入的元素:”);rewind(stdin);scanf(“%c”,&e);InsList(L,i,e);break;case 6: printf(“輸入要?jiǎng)h除第幾個(gè)結(jié)點(diǎn):”);scanf(“%d”,&i);DelList(L,i,&e);break;case 7: ListLength(L);break;case 8: flag=1;break;}

      八、實(shí)驗(yàn)內(nèi)容二測試數(shù)據(jù)與實(shí)驗(yàn)結(jié)果:

      第二篇:數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

      注意:實(shí)驗(yàn)結(jié)束后提交一份實(shí)驗(yàn)報(bào)告電子文檔

      電子文檔命名為“學(xué)號(hào)+姓名”,如:E01214058宋思怡

      《數(shù)據(jù)結(jié)構(gòu)》實(shí)驗(yàn)報(bào)告

      (一)學(xué)號(hào):姓名:專業(yè)年級(jí):

      實(shí)驗(yàn)名稱:線性表

      實(shí)驗(yàn)日期:2014年4月14日

      實(shí)驗(yàn)?zāi)康模?/p>

      1、熟悉線性表的定義及其順序和鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu);

      2、熟練掌握線性表在順序存儲(chǔ)結(jié)構(gòu)上實(shí)現(xiàn)基本操作的方法;

      3、熟練掌握在各種鏈表結(jié)構(gòu)中實(shí)現(xiàn)線性表基本操作的方法;

      4、掌握用 C/C++語言調(diào)試程序的基本方法。

      實(shí)驗(yàn)內(nèi)容:

      一、編寫程序?qū)崿F(xiàn)順序表的各種基本運(yùn)算,并在此基礎(chǔ)上設(shè)計(jì)一個(gè)主程序完成如下功能:

      (1)初始化順序表L;

      (2)依次在L尾部插入元素-1,21,13,24,8;

      (3)輸出順序表L;

      (4)輸出順序表L長度;

      (5)判斷順序表L是否為空;

      (6)輸出順序表L的第3個(gè)元素;

      (7)輸出元素24的位置;

      (8)在L的第4個(gè)元素前插入元素0;

      (9)輸出順序表L;

      (10)刪除L的第5個(gè)元素;

      (11)輸出順序表L。

      源代碼

      調(diào)試分析(給出運(yùn)行結(jié)果界面)

      二、編寫程序?qū)崿F(xiàn)單鏈表的各種基本運(yùn)算,并在此基礎(chǔ)上設(shè)計(jì)一個(gè)主程序完成如下功能:

      ????

      ????

      小結(jié)或討論:

      (1)實(shí)驗(yàn)中遇到的問題和解決方法

      (2)實(shí)驗(yàn)中沒有解決的問題

      (3)體會(huì)和提高

      第三篇:數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

      南京信息工程大學(xué)實(shí)驗(yàn)(實(shí)習(xí))報(bào)告

      實(shí)驗(yàn)(實(shí)習(xí))名稱數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)(實(shí)習(xí))日期 2011-11-2得分指導(dǎo)教師周素萍

      系公共管理系專業(yè)信息管理與信息系統(tǒng)年級(jí)10級(jí)班次1姓名常玲學(xué)號(hào)2010230700

      3實(shí)驗(yàn)一順序表的基本操作及C語言實(shí)現(xiàn)

      【實(shí)驗(yàn)?zāi)康摹?/p>

      1、順序表的基本操作及 C 語言實(shí)現(xiàn)

      【實(shí)驗(yàn)要求】

      1、用 C 語言建立自己的線性表結(jié)構(gòu)的程序庫,實(shí)現(xiàn)順序表的基本操作。

      2、對(duì)線性表表示的集合,集合數(shù)據(jù)由用戶從鍵盤輸入(數(shù)據(jù)類型為整型),建立相應(yīng)的順序表,且使得數(shù)據(jù)按從小到大的順序存放,將兩個(gè)集合的并的結(jié)果存儲(chǔ)在一個(gè)新的線性表集合中,并輸出。

      【實(shí)驗(yàn)內(nèi)容】

      1、根據(jù)教材定義的順序表機(jī)構(gòu),用 C 語言實(shí)現(xiàn)順序表結(jié)構(gòu)的創(chuàng)建、插入、刪除、查找等操作;

      2、利用上述順序表操作實(shí)現(xiàn)如下程序:建立兩個(gè)順序表表示的集合(集合中無重

      復(fù)的元素),并求這樣的兩個(gè)集合的并。

      【實(shí)驗(yàn)結(jié)果】

      [實(shí)驗(yàn)數(shù)據(jù)、結(jié)果、遇到的問題及解決]

      一. Status InsertOrderList(SqList &va,ElemType x)

      {

      }

      二. Status DeleteK(SqList &a,int i,int k)

      {//在非遞減的順序表va中插入元素x并使其仍成為順序表的算法 int i;if(va.length==va.listsize)return(OVERFLOW);for(i=va.length;i>0,x

      }

      //注意i的編號(hào)從0開始 int j;if(i<0||i>a.length-1||k<0||k>a.length-i)return INFEASIBLE;for(j=0;j<=k;j++)a.elem[j+i]=a.elem[j+i+k];a.length=a.length-k;return OK;

      三.// 將合并逆置后的結(jié)果放在C表中,并刪除B表

      Status ListMergeOppose_L(LinkList &A,LinkList &B,LinkList &C)

      {

      LinkList pa,pb,qa,qb;pa=A;pb=B;qa=pa;qb=pb;// 保存pa的前驅(qū)指針 // 保存pb的前驅(qū)指針 pa=pa->next;pb=pb->next;A->next=NULL;C=A;while(pa&&pb){} while(pa){} qa=pa;pa=pa->next;qa->next=A->next;A->next=qa;if(pa->data

      data){} else{} qb=pb;pb=pb->next;qb->next=A->next;//將當(dāng)前最小結(jié)點(diǎn)插入A表表頭 A->next=qb;qa=pa;pa=pa->next;qa->next=A->next;//將當(dāng)前最小結(jié)點(diǎn)插入A表表頭 A->next=qa;

      }

      } pb=B;free(pb);return OK;qb=pb;pb=pb->next;qb->next=A->next;A->next=qb;

      順序表就是把線性表的元素存儲(chǔ)在數(shù)組中,元素之間的關(guān)系直接通過相鄰元素的位置來表達(dá)。

      優(yōu)點(diǎn):簡單,數(shù)據(jù)元素的提取速度快;

      缺點(diǎn):(1)靜態(tài)存儲(chǔ),無法預(yù)知問題規(guī)模的大小,可能空間不足,或浪費(fèi)存儲(chǔ)空間;(2)插入元素和刪除元素時(shí)間復(fù)雜度高——O(n)

      求兩個(gè)集合的并集

      該算法是求兩個(gè)集合s1和s2的并集,并將結(jié)果存入s引用參數(shù)所表示的集合中帶回。首先把s1集合復(fù)制到s中,然后把s2中的每個(gè)元素依次插入到集合s中,當(dāng)然重復(fù)的元素不應(yīng)該被插入,最后在s中就得到了s1和s2的并集,也就是在s所對(duì)應(yīng)的實(shí)際參數(shù)集合中得到并集。

      第四篇:數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

      數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

      一. 題目要求

      1)編程實(shí)現(xiàn)二叉排序樹,包括生成、插入,刪除; 2)對(duì)二叉排序樹進(jìn)行先根、中根、和后根非遞歸遍歷;

      3)每次對(duì)樹的修改操作和遍歷操作的顯示結(jié)果都需要在屏幕上用樹的形狀表示出來。4)分別用二叉排序樹和數(shù)組去存儲(chǔ)一個(gè)班(50人以上)的成員信息(至少包括學(xué)號(hào)、姓名、成績3項(xiàng)),對(duì)比查找效率,并說明在什么情況下二叉排序樹效率高,為什么? 二. 解決方案

      對(duì)于前三個(gè)題目要求,我們用一個(gè)程序?qū)崿F(xiàn)代碼如下 #include #include #include #include “Stack.h”//棧的頭文件,沒有用上

      typedefintElemType;

      //數(shù)據(jù)類型 typedefint Status;

      //返回值類型 //定義二叉樹結(jié)構(gòu) typedefstructBiTNode{ ElemType

      data;

      structBiTNode *lChild, *rChild;//左右子樹域 }BiTNode, *BiTree;intInsertBST(BiTree&T,int key){//插入二叉樹函數(shù)

      if(T==NULL){

      T =(BiTree)malloc(sizeof(BiTNode));

      T->data=key;

      T->lChild=T->rChild=NULL;

      return 1;} else if(keydata){ InsertBST(T->lChild,key);} else if(key>T->data){

      InsertBST(T->rChild,key);} else

      return 0;} BiTreeCreateBST(int a[],int n){//創(chuàng)建二叉樹函數(shù) BiTreebst=NULL;inti=0;while(i

      //數(shù)據(jù)域

      InsertBST(bst,a[i]);

      i++;} returnbst;} int Delete(BiTree&T)

      {

      BiTreeq,s;

      } if(!(T)->rChild){ //右子樹為空重接它的左子樹

      q=T;T=(T)->lChild;free(q);}else{

      if(!(T)->lChild){ //若左子樹空則重新接它的右子樹

      q=T;T=(T)->rChild;}else{ q=T;s=(T)->lChild;while(s->rChild){

      q=s;s=s->rChild;}

      (T)->data=s->data;//s指向被刪除結(jié)點(diǎn)的前驅(qū)

      if(q!=T)

      q->rChild=s->lChild;

      else

      q->lChild=s->lChild;

      free(s);} } return 1;

      //刪除函數(shù),在T中刪除key元素 intDeleteBST(BiTree&T,int key){ if(!T)return 0;else{

      if(key==(T)->data)return Delete(T);

      else{

      if(key<(T)->data)

      returnDeleteBST(T->lChild,key);

      else

      returnDeleteBST(T->rChild,key);

      } } } intPosttreeDepth(BiTree T){//求深度

      inthr,hl,max;if(!T==NULL){ hl=PosttreeDepth(T->lChild);hr=PosttreeDepth(T->rChild);max=hl>hr?hl:hr;return max+1;} else

      return 0;

      } void printtree(BiTreeT,intnlayer){//打印二叉樹 if(T==NULL)return;printtree(T->rChild,nlayer+1);for(inti=0;i

      ”);} printf(“%dn”,T->data);printtree(T->lChild,nlayer+1);} void PreOrderNoRec(BiTree root)//先序非遞歸遍歷 { BiTree p=root;BiTreestack[50];intnum=0;while(NULL!=p||num>0){

      while(NULL!=p)

      {

      printf(“%d ”,p->data);

      stack[num++]=p;

      p=p->lChild;

      }

      num--;

      p=stack[num];

      p=p->rChild;} printf(“n”);} void InOrderNoRec(BiTree root)//中序非遞歸遍歷 { BiTree p=root;

      } intnum=0;BiTreestack[50];while(NULL!=p||num>0){ while(NULL!=p){

      stack[num++]=p;

      p=p->lChild;} num--;p=stack[num];printf(“%d ”,p->data);p=p->rChild;} printf(“n”);void PostOrderNoRec(BiTree root)//后序非遞歸遍歷 { BiTree p=root;BiTreestack[50];intnum=0;BiTreehave_visited=NULL;

      while(NULL!=p||num>0){

      while(NULL!=p)

      {

      stack[num++]=p;

      p=p->lChild;

      }

      p=stack[num-1];

      if(NULL==p->rChild||have_visited==p->rChild)

      {

      printf(“%d ”,p->data);

      num--;

      have_visited=p;

      p=NULL;

      }

      else

      {

      p=p->rChild;

      } } printf(“n”);}

      int main(){//主函數(shù)

      printf(“

      ---------------------二叉排序樹的實(shí)現(xiàn)-------------------”);printf(“n”);int layer;inti;intnum;printf(“輸入節(jié)點(diǎn)個(gè)數(shù):”);scanf(“%d”,&num);printf(“依次輸入這些整數(shù)(要不相等)”);int *arr=(int*)malloc(num*sizeof(int));for(i=0;i

      scanf(“%d”,arr+i);} BiTreebst=CreateBST(arr,num);printf(“n”);printf(“二叉樹創(chuàng)建成功!”);printf(“n”);layer=PosttreeDepth(bst);printf(“樹狀圖為:n”);printtree(bst,layer);int j;int T;int K;for(;;){ loop: printf(“n”);printf(“

      ***********************按提示輸入操作符************************:”);printf(“n”);printf(“

      1:插入節(jié)點(diǎn)

      2:刪除節(jié)點(diǎn)

      3:打印二叉樹

      4:非遞歸遍歷二叉樹

      5:退出”);scanf(“%d”,&j);

      switch(j){

      case 1:

      printf(“輸入要插入的節(jié)點(diǎn):”);

      scanf(“%d”,&T);

      InsertBST(bst,T);

      printf(“插入成功!”);printf(“樹狀圖為:n”);

      printtree(bst,layer);

      break;

      case 2:

      }

      printf(“輸入要?jiǎng)h除的節(jié)點(diǎn)”);scanf(“%d”,&K);DeleteBST(bst,K);printf(“刪除成功!”);printf(“樹狀圖為:n”);printtree(bst,layer);break;case 3: layer=PosttreeDepth(bst);printtree(bst,layer);break;case 4:

      printf(“非遞歸遍歷二叉樹”);printf(“先序遍歷:n”);PreOrderNoRec(bst);printf(“中序遍歷:n”);InOrderNoRec(bst);

      printf(“后序遍歷:n”);

      PostOrderNoRec(bst);

      printf(“樹狀圖為:n”);

      printtree(bst,layer);

      break;case 5:

      printf(“程序執(zhí)行完畢!”);

      return 0;} goto loop;} return 0;對(duì)于第四小問,要儲(chǔ)存學(xué)生的三個(gè)信息,需要把上面程序修改一下,二叉樹結(jié)構(gòu)變?yōu)?typedefintElemType;

      //數(shù)據(jù)類型 typedefstring SlemType;

      typedefint Status;

      //返回值類型 //定義二叉樹結(jié)構(gòu) typedefstructBiTNode{ SlemType name;ElemType score;ElemType no;

      //數(shù)據(jù)域 structBiTNode *lChild, *rChild;//左右子樹域 }BiTNode, *BiTree;參數(shù)不是key,而是另外三個(gè)

      intInsertBST(BiTree&T,intno,intscore,string name){//插入二叉樹函數(shù)

      if(T==NULL){

      T =(BiTree)malloc(sizeof(BiTNode));

      T->no=no;T->name=name;T->score=score;

      T->lChild=T->rChild=NULL;

      return 1;} else if(nono){ InsertBST(T->lChild,no,score,name);} else if(key>T->data){

      InsertBST(T->rChild,no,score,name);} else

      return 0;} 其他含參函數(shù)也類似 即可完成50個(gè)信息存儲(chǔ)

      用數(shù)組存儲(chǔ)50個(gè)信息,查看以往代碼

      #include #include using namespace std;class student{ private: intnum;string name;int ob1;int ob2;intara;public: void set(inta,stringb,intc,int d);void show();int average();};void student ::set(inta,stringb,intc,int d){ num=a;name=b;ob1=c;ob2=d;ara=(c+d)/2;} void student::show(){ cout<<“學(xué)號(hào):”<

      int main(){ cout<<“ 歡迎來到學(xué)生管理系統(tǒng)”<>numlock;switch(numlock){ case 0: cout<<“輸入想查詢的學(xué)號(hào)”<>i;if(i==j){ cout<<“該學(xué)號(hào)信息已被刪除”<>j;delete[j]ptr;cout<<“刪除成功”<>k;if(k!=j){

      cout<<“該學(xué)號(hào)信息已經(jīng)存在,添加失敗”<

      break;} cout<<“重新輸入添加的學(xué)號(hào)”<>q;cout<<“輸入姓名”<>w;cout<<“輸入科目一的成績”<>e;cout<<“輸入科目二的成績”<>r;ptr[k].set(q,w,e,r);break;case 3: for(m=1;m<20;m++){

      for(int n=m+1;n<20;n++){

      if(ptr[m].average()

      student a;

      a=ptr[m];

      ptr[m]=ptr[n];

      ptr[n]=a;

      }}

      ptr[m].show();} break;case 4: cout<<“謝謝使用”<

      二叉排序樹儲(chǔ)存數(shù)據(jù)界面(儲(chǔ)存學(xué)生信息略)

      創(chuàng)建二叉樹:

      插入節(jié)點(diǎn):

      刪除節(jié)點(diǎn):

      非遞歸遍歷:

      退出:

      數(shù)組儲(chǔ)存學(xué)生信息界面

      分析查找效率:

      因?yàn)槎鏄洳檎乙獎(jiǎng)?chuàng)建二叉樹,而數(shù)組查找只創(chuàng)建一個(gè)數(shù)組,二叉樹的創(chuàng)建時(shí)間比較長,所以對(duì)于數(shù)據(jù)量較少的情況下數(shù)組的查找效率比較高。但當(dāng)數(shù)據(jù)量增加時(shí),二叉樹的查找優(yōu)勢就顯現(xiàn)出來。所以數(shù)據(jù)量越大的時(shí)候,二叉樹的查找效率越高。

      四. 總結(jié)與改進(jìn)

      這個(gè)實(shí)驗(yàn)工作量還是很大的,做了很久。樹狀圖形輸出還是不美觀,還需要改進(jìn)。

      一開始打算用棧實(shí)現(xiàn)非遞歸,但是根據(jù)書里面的偽代碼發(fā)現(xiàn)部分是在C++編譯器里運(yùn)行不了的(即使補(bǔ)充了頭文件和數(shù)據(jù)的定義),所以之后參考了網(wǎng)上的數(shù)組非遞歸,發(fā)現(xiàn)其功能和棧相似。

      遞歸遍歷的實(shí)現(xiàn)比非遞歸的遍歷真的簡單很多。

      開始時(shí)只看到前三問,所以沒有寫到儲(chǔ)存學(xué)生數(shù)據(jù)的代碼,里面還可以用clock()函數(shù)加一個(gè)計(jì)算查找所要數(shù)據(jù)時(shí)間的代碼,讓二叉樹查找與數(shù)組查找到效率比較更加直觀。

      第五篇:數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

      實(shí)驗(yàn)報(bào)告4 排序

      一、實(shí)驗(yàn)?zāi)康?/p>

      1、掌握常用的排序方法,并掌握用高級(jí)語言實(shí)現(xiàn)排序算法的方法。

      2、深刻理解排序的定義和各種排序方法的特點(diǎn),并能加以靈活應(yīng)用。

      3、了解各種方法的排序過程及其依據(jù)的原則,并掌握各種排序方法的時(shí)間復(fù)雜度的分析方法。

      二、實(shí)驗(yàn)要求及內(nèi)容

      要求編寫的程序所能實(shí)現(xiàn)的功能包括:

      1、從鍵盤輸入要排序的一組元素的總個(gè)數(shù)

      2、從鍵盤依次輸入要排序的元素值

      3、對(duì)輸入的元素進(jìn)行快速排序

      4、對(duì)輸入的元素進(jìn)行折半插入排序

      三、實(shí)驗(yàn)代碼及相關(guān)注釋

      #include using namespace std;#include “malloc.h”

      typedef struct { int key;}RedType;

      typedef struct { RedType r[100];int length;}SqList;

      //1 快速排序的結(jié)構(gòu)體

      typedef struct {

      int data[100];

      int last;}Sequenlist;//2 折半插入排序的結(jié)構(gòu)體

      int Partition(SqList &L, int low, int high)

      //1 尋找基準(zhǔn)

      {

      L.r[0]=L.r[low];//子表的第一個(gè)記錄作基準(zhǔn)對(duì)象

      int pivotkey = L.r[low].key;//基準(zhǔn)對(duì)象關(guān)鍵字 while(low

      while(low= pivotkey)--high;

      L.r[low] = L.r[high];//小于基準(zhǔn)對(duì)象的移到區(qū)間的左側(cè)

      while(low

      L.r[high] = L.r[low];//大于基準(zhǔn)對(duì)象的移到區(qū)間的右側(cè) }

      L.r[low] = L.r[0];return low;}

      void QuickSort(SqList &L, int low, int high)

      //1 快速排序 { //在序列l(wèi)ow-high中遞歸地進(jìn)行快速排序

      if(low < high)

      {

      int pivotloc= Partition(L, low, high);

      //尋找基準(zhǔn)

      QuickSort(L, low, pivotloc-1);//對(duì)左序列同樣遞歸處理

      QuickSort(L, pivotloc+1, high);//對(duì)右序列同樣遞歸處理

      } }

      Sequenlist *Sqlset()

      //2 輸入要折半插入排序的一組元素

      {

      Sequenlist *L;

      int i;

      L=(Sequenlist *)malloc(sizeof(Sequenlist));

      L->last=0;

      cout<<“請(qǐng)輸入要排序的所有元素的總個(gè)數(shù):”;

      cin>>i;

      cout<

      cout<<“請(qǐng)依次輸入所有元素的值:”;

      if(i>0)

      {

      for(L->last=1;L->last<=i;L->last++)

      cin>>L->data[L->last];

      L->last--;

      }

      return(L);}

      middlesort(Sequenlist *L)

      //2 折半插入排序 { int i,j,low,high,mid;for(i=1;i<=L->last;i++){

      L->data[0]=L->data[i];

      low=1;

      high=i-1;

      while(low<=high)

      {

      mid=(low+high)/2;

      if(L->data[0]data[mid])

      high=mid-1;//插入點(diǎn)在前半?yún)^(qū)

      else

      low=mid+1;//插入點(diǎn)在后半?yún)^(qū)

      }

      for(j=i;j>high+1;j--){ L->data[j]=L->data[j-1];} //后移

      L->data[high+1]=L->data[0];//插入 } return 0;}

      int main(){ gg: cout<<“請(qǐng)選擇功能(1.快速排序 2.折半插入排序 3.退出程序):”;int m;cin>>m;cout<

      if(m==1){ SqList L;int n;cout<<“請(qǐng)輸入要排序的所有元素的總個(gè)數(shù):”;cin>>n;cout<

      cin>>L.r[i].key;

      } cout<

      QuickSort(L,1,L.length);

      for(int j=1;j<=L.length;j++)

      {

      cout<

      }

      cout<

      cout<

      }

      if(m==2){

      Sequenlist *L;

      int i;

      L=Sqlset();

      cout<

      middlesort(L);

      cout<<“折半插入排序后為:”;

      for(i=1;i<=L->last;i++)

      {

      cout<data[i]<<“ ”;

      }

      cout<

      cout<

      goto gg;}

      if(m==3){

      exit(0);

      cout<

      四、重要函數(shù)功能說明

      1、Sequenlist *Sqlset()

      輸入要折半插入排序的一組元素

      2、int Partition(SqList &L, int low, int high)

      尋找快速排序的基準(zhǔn)

      3、void QuickSort(SqList &L, int low, int high)

      快速排序

      4、middlesort(Sequenlist *L)

      折半插入排序

      五、程序運(yùn)行結(jié)果

      下圖僅為分別排序一次,可多次排序,后面有相關(guān)截圖:

      六、實(shí)驗(yàn)中遇到的問題、解決及體會(huì)

      1、起初編寫快速排序的程序時(shí),我是完全按照老師PPT上的算法敲上去的,然后建立了一個(gè)SqList的結(jié)構(gòu)體,調(diào)試運(yùn)行時(shí)出現(xiàn)錯(cuò)誤,仔細(xì)查看才意識(shí)到Partition函數(shù)中L中應(yīng)該包含元素key,而我建立結(jié)構(gòu)體時(shí)沒有注意,然后我將key這個(gè)元素補(bǔ)充進(jìn)去,繼續(xù)調(diào)試,又出現(xiàn)錯(cuò)誤,提示我Partition沒有定義,我就覺得很奇怪,我明明已經(jīng)寫了函數(shù)定義,為什么會(huì)這樣,當(dāng)我又回過頭來閱讀程序時(shí),我發(fā)現(xiàn)QuickSort函數(shù)中調(diào)用了Partition函數(shù),但是我的Partition函數(shù)的定義在QuickSort函數(shù)的后面,于是我將Partition函數(shù)放到了QuickSort函數(shù)的前面,再次調(diào)試運(yùn)行,就可以正常運(yùn)行,得出結(jié)果了。這讓我懂得,編程一定要認(rèn)真仔細(xì),不可大意馬虎,否則又會(huì)花很多時(shí)間回過頭來檢查修改程序,得不償失。

      運(yùn)行程序錯(cuò)誤截圖:

      2、本來我是編寫了兩個(gè)程序,分別實(shí)現(xiàn)快速排序和折半插入排序的功能,但我后來想我是否可以將其合二為一,于是我想到用if選擇語句用來實(shí)現(xiàn)不同的功能,從鍵盤輸入功能選項(xiàng)m,if(m==1),可以進(jìn)行快速排序,if(m==2),可以進(jìn)行折半插入排序,于是我繼續(xù)思考,我是否可以在一次運(yùn)行程序中,多次對(duì)含有不同元素的序列進(jìn)行排序,于是我用了goto語句,每次排序一次后,自動(dòng)循環(huán)到選擇語句,當(dāng)不需要在排序的時(shí)候,可以從鍵盤輸入3,退出程序,這樣一來,程序變得更加實(shí)用和清晰明朗。這讓我懂得,想要編出好的程序,要善于思考,在實(shí)現(xiàn)所需功能的前提下,多想問題,看是否能使程序更加實(shí)用簡便。

      修改程序前兩個(gè)運(yùn)行結(jié)果截圖

      (兩個(gè)程序,調(diào)試運(yùn)行兩次,每次只能進(jìn)行一次排序)

      1、快速排序程序運(yùn)行結(jié)果截圖:

      2、折半插入排序程序結(jié)果截圖:

      程序重要模塊修改截圖:

      修改程序后運(yùn)行截圖:

      (一個(gè)程序,調(diào)試運(yùn)行一次,可多次進(jìn)行不同序列的不同排序)

      下載數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告.doc(范文大全)word格式文檔
      下載數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告.doc(范文大全).doc
      將本文檔下載到自己電腦,方便修改和收藏,請(qǐng)勿使用迅雷等下載。
      點(diǎn)此處下載文檔

      文檔為doc格式


      聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn)自行上傳,本網(wǎng)站不擁有所有權(quán),未作人工編輯處理,也不承擔(dān)相關(guān)法律責(zé)任。如果您發(fā)現(xiàn)有涉嫌版權(quán)的內(nèi)容,歡迎發(fā)送郵件至:645879355@qq.com 進(jìn)行舉報(bào),并提供相關(guān)證據(jù),工作人員會(huì)在5個(gè)工作日內(nèi)聯(lián)系你,一經(jīng)查實(shí),本站將立刻刪除涉嫌侵權(quán)內(nèi)容。

      相關(guān)范文推薦

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

        數(shù) 據(jù) 結(jié) 構(gòu) 實(shí) 驗(yàn) 報(bào) 告 1.問題描述 為某個(gè)單位建立一個(gè)員工通訊錄管理系統(tǒng),可以方便地查詢每一個(gè)員工的辦公室電話號(hào)碼、手機(jī)號(hào)碼及電子郵箱。 2. 設(shè)計(jì)分析 在本設(shè)計(jì)中,整......

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告 第一次實(shí)驗(yàn) 學(xué)號(hào):20141060106 姓名:葉佳偉 一、實(shí)驗(yàn)?zāi)康?1、復(fù)習(xí)變量、數(shù)據(jù)類型、語句、函數(shù); 2、掌握函數(shù)的參數(shù)和值; 3、了解遞歸。 二、實(shí)驗(yàn)內(nèi)容 1、(必做......

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

        天 津 科 技 大 學(xué) 14學(xué)年—15學(xué)年第 2 學(xué)期 數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)任務(wù)書 專業(yè)名稱: 計(jì)算機(jī)科學(xué)與技術(shù) 實(shí)驗(yàn)學(xué)時(shí): 4 課程名稱:數(shù)據(jù)結(jié)構(gòu) 任課教師: 史紹強(qiáng) 實(shí)驗(yàn)題目:圖的最短路徑算法的實(shí)......

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

        河南省高等教育自學(xué)考試 實(shí) 驗(yàn) 報(bào) 告 冊 計(jì)算機(jī)及應(yīng)用專業(yè)(本科段) 《數(shù)據(jù)結(jié)構(gòu)》姓名周東偉準(zhǔn)考證號(hào)010512201008所屬地市鄭州實(shí)驗(yàn)地點(diǎn)河南職業(yè)技術(shù)學(xué)院實(shí)驗(yàn)日期2014-3-18實(shí)驗(yàn)......

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告 指導(dǎo)教師 姓 名班 級(jí)學(xué) 號(hào)實(shí)驗(yàn) 室 黃梅根鐘志偉 0140703 07310325 S331-B 2008-11-29 單鏈表的插入和刪除實(shí)驗(yàn)日志 指導(dǎo)教師:黃梅根實(shí)驗(yàn)時(shí)間:2008年10月1......

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告 實(shí)驗(yàn)名稱數(shù)據(jù)結(jié)構(gòu)與算法專業(yè)班級(jí) 數(shù)學(xué)與應(yīng)用數(shù)學(xué)1201班 學(xué)號(hào) 1304120306 姓名謝 偉 指導(dǎo)老師陳 明......

        數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)報(bào)告

        浙江師范大學(xué) 實(shí) 驗(yàn) 報(bào) 告 學(xué) 院: 數(shù)理與信息工程學(xué)院 專 業(yè): 計(jì)算機(jī)科學(xué)與技術(shù) 姓 名: 楊富生 學(xué) 號(hào): 201531910137 課程名稱: 數(shù)據(jù)結(jié)構(gòu) 指導(dǎo)教師: 鐘發(fā)榮 實(shí)驗(yàn)時(shí)間: 2016-06-15......

        2012數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)

        數(shù) 據(jù) 結(jié) 構(gòu) 課程設(shè)計(jì)報(bào)告 題 目: 一元多項(xiàng)式計(jì)算 專 業(yè): 信息管理與信息系統(tǒng) 班 級(jí): 2012級(jí)普本班 學(xué) 號(hào): 201201011367 姓 名: 左帥帥 指導(dǎo)老師: 郝慎學(xué) 時(shí) 間: 一、課程設(shè)計(jì)題目......