第一篇:數據結構課程設計
《數據結構》
課程設計報告
學 號 姓 名 班 級 指導教師
XXX XXX XXX XXX 安徽工業大學計算機學院
2014年6月
利用棧實現迷宮問題的求解
一、問題描述
以一個M*N的長方陣表示迷宮,0和1分別表示迷宮中的通路和墻壁。設計一個程序,對任意設定的迷宮,求出一條從入口到出口的通路,或得出米有通路的結論。
二、設計思路
(1)以二維數組maze[m][n]表示迷宮,數組中元素值為0表示通路,1表示障礙。
(2)其中迷宮的入口位置和出口位置默認于maze數組的起始元素位置和最后個元素位置。
(3)以鏈表作存儲結構的棧類型,實現求解迷宮的非遞歸程序。
三、數據結構定義 typedef struct{
int x;int y;}item;typedef struct{ int x,y,d;}DataType;typedef struct{ DataType data[1000];int top;}SeqStack,*PSeqStack;
typedef struct{ DataType data[1000];int top;}SeqStack,*PSeqStack;
四、程序清單 #include
{1,0,1,1,1,0,1,1,1,1}, {1,0,0,0,0,1,1,1,1,1}, {1,0,1,0,0,0,0,0,1,1}, {1,0,1,1,1,0,0,1,1,1}, {1,1,0,0,1,1,0,0,0,1}, {1,0,1,1,0,0,1,1,0,1}, {1,1,1,1,1,1,1,1,1,1}};int x;int y;}item;
item move[4]={{0,1},{1,0},{0,-1},{-1,0}};
typedef struct{ int x,y,d;}DataType;
typedef struct{ DataType data[1000];int top;}SeqStack,*PSeqStack;
PSeqStack Init_SeqStack(){
} PSeqStack p;p=(PSeqStack)malloc(sizeof(SeqStack));if(p)p->top=-1;return p;
int Empty_SeqStack(PSeqStack p){
}
int Push_SeqStack(PSeqStack p,DataType x){
}
int Pop_SeqStack(PSeqStack p,DataType *x){ if(p->top==999)return 0;if(p->top==-1)return 1;else return 0;else {
} p->top++;p->data[p->top]=x;return 1;
} if(Empty_SeqStack(p))return 0;else {
} *x=p->data[p->top];p->top--;return 1;void Destroy_SeqStack(PSeqStack *p){
}
int mazepath(int maze[][n+2],item move[],int x0,int y0){
PSeqStack S;DataType temp;int x,y,d,i,j;if(*p)free(*p);*p=NULL;return;
temp.x=x0;temp.y=y0;temp.d=-1;S=Init_SeqStack();if(!S){
} Push_SeqStack(S,temp);while(!Empty_SeqStack(S)){
Pop_SeqStack(S,&temp);x=temp.x;y=temp.y;d=temp.d+1;while(d<4){
i=x+move[d].x;j=y+move[d].y;if(0==maze[i][j]){ temp.x=x;printf(“棧初始化失敗!!”);return 0;
}
}
} temp.y=y;temp.d=d;Push_SeqStack(S,temp);x=i;y=j;maze[x][y]=-1;if(x==m&&y==n){
} else d=0;while(!Empty_SeqStack(S)){
} Destroy_SeqStack(&S);return 1;Pop_SeqStack(S,&temp);printf(“(%d,%d)<-”,temp.x,temp.y);else d++;
} Destroy_SeqStack(&S);return 0;int main(){
}
五、運行及調試分析 mazepath(maze,move,1,1);return 0;
六、課程設計總結等
在做實驗前,一定要將課本上的知識吃透,因為這是做實驗的基礎,否則,在做設計程序實驗時,這將使你做的難度加大,浪費寶貴的時間.使你事倍功半.做實驗時,一定要親力親為,務必要將每個步驟,每個細節弄清楚,弄明白,實驗后,還要復習,思考,這樣,你的印象才深刻,記得才牢固,否則,過后不久你就會忘得一干二凈,這還不如不做.通過這次程序設計的實驗,使我們學到了不少實用的知識,更重要的是,做實驗的過程,思考問題的方法,這與做其他的實驗是通用的,真正使我們們受益匪淺。
大數相乘
一、問題描述
本問題中,要求輸入兩個相對較大的正整數,能夠通過程序計算出其結果
二、設計思路
1.輸入階段采用一維數組a[],b[] 在輸入階段當大數輸入時,大數a,b從高位到低位分別依次存入數組a[ ],b[ ]。
2.調用函數計算階段采用一維數組c[ ] 在計算過程中,由個位到高位依次計算各位的結果,并依次存入數組c[ ]中。
三、數據結構定義
int x[N],y[N],z[N*N];
四、程序清單 #include
五、運行及調試分析
六、課程設計總結。
回顧起此次課程設計,至今我仍感慨頗多,的確,從從拿到題目到完成整個編程,從理論到實踐,可以學到很多很多的的東西,同時不僅可以鞏固了以前所學過的知識,而且學到了很多在書本上所沒有學到過的知識。通過這次課程設計使我懂得了理論與實際相結合是很重要的,只有理論知識是遠遠不夠的,只有把所學的理論知識與實踐相結合起來,從理論中得出結論,才能真正提高自己的實際動手能力和獨立思考的能力。
第二篇:2012數據結構課程設計
數 據 結 構
課程設計報告
題 目: 一元多項式計算 專 業: 信息管理與信息系統 班 級: 2012級普本班 學 號: 201201011367 姓 名: 左帥帥 指導老師: 郝慎學 時 間:
一、課程設計題目分析
本課程設計要求利用C語言或C++編寫,本程序實現了一元多項式的加法、減法、乘法、除法運算等功能。
二、設計思路
本程序采用C語言來完成課程設計。
1、首先,利用順序存儲結構來構造兩個存儲多項式A(x)和 B(x)的結構。
2、然后把輸入,加,減,乘,除運算分成五個主要的模塊:實現多項式輸入模塊、實現加法的模塊、實現減法的模塊、實現乘法的模塊、實現除法的模塊。
3、然后各個模塊里面還要分成若干種情況來考慮并通過函數的嵌套調用來實現其功能,盡量減少程序運行時錯誤的出現。
4、最后編寫main()主函數以實現對多項式輸入輸出以及加、減、乘、除,調試程序并將不足的地方加以修改。
三、設計算法分析
1、相關函數說明:
(1)定義數據結構類型為線性表的鏈式存儲結構類型變量
typedef struct Polynomial{}
(2)其他功能函數
插入函數void Insert(Polyn p,Polyn h)
比較函數int compare(Polyn a,Polyn b)
建立一元多項式函數Polyn Create(Polyn head,int m)
求解并建立多項式a+b,Polyn Add(Polyn pa,Polyn pb)
求解并建立多項式a-b,Polyn Subtract(Polyn pa,Polyn pb)2
求解并建立多項式a*b,Polyn Multiply(Polyn pa,Polyn pb)
求解并建立多項式a/b,void Device(Polyn pa,Polyn pb)
輸出函數輸出多項式,void Print(Polyn P)
銷毀多項式函數釋放內存,void Destroy(Polyn p)
主函數,void main()
2、主程序的流程基函數調用說明(1)typedef struct Polynomial {
float coef;
int expn;
struct Polynomial *next;} *Polyn,Polynomial;
在這個結構體變量中coef表示每一項前的系數,expn表示每一項的指數,polyn為結點指針類型,屬于抽象數據類型通常由用戶自行定義,Polynomial表示的是結構體中的數據對象名。
(2)當用戶輸入兩個一元多項式的系數和指數后,建立鏈表,存儲這兩個多項式,主要說明如下:
Polyn CreatePolyn(Polyn head,int m)建立一個頭指針為head、項數為m的一元多項式
p=head=(Polyn)malloc(sizeof(struct Polynomial));為輸入的多項式申請足夠的存儲空間
p=(Polyn)malloc(sizeof(struct Polynomial));建立新結點以接收數據
Insert(p,head);調用Insert函數插入結點
這就建立一元多項式的關鍵步驟
(3)由于多項式的系數和指數都是隨即輸入的,所以根據要求需要對多項式按指數進行降冪排序。在這個程序模塊中,使用鏈表,根據對指數大小的比較,對各種情況進行處理,此處由于反復使用指針對各個結點進行定位,找到合適的位置再利用void Insert(Polyn p,Polyn h)進行插入操作。(4)加、減、乘、除、的算法實現:
在該程序中,最關鍵的一步是實現四則運算和輸出,由于加減算法原則是一樣,減法可通過系數為負的加法實現;對于乘除算法的大致流程都是:首先建立多項式a*b,a/b,然后使用鏈表存儲所求出的乘積,商和余數。這就實現了多項式計算模塊的主要功能。
(5)另一個子函數是輸出函數 PrintPolyn();
輸出最終的結果,算法是將最后計算合并的鏈表逐個結點依次輸出,便得到整鏈表,也就是最后的計算式計算結果。由于考慮各個結點的指數情況不同,分別進行了判斷處理。
四、程序新點
通過多次寫程序,發現在程序在控制臺運行時總是黑色的,本次寫程序就想著改變一下,于是經過查資料利用system(“Color E0”);可以函數解決,這里“E0,”E是控制臺背景顏色,0是控制臺輸出字體顏色。
五、設計中遇到的問題及解決辦法
首先是,由于此次課程設計里使用指針使用比較多,自己在指針多的時候易腦子混亂出錯,對于此問題我是采取比較笨的辦法在稿紙上寫明白后開始進行 4
代碼編寫。
其次是,在寫除法模塊時比較復雜,自己通過查資料最后成功寫出除法模塊功能。
最后是,前期分析不足開始急于寫代碼,中途出現各種問題,算是給自己以后設計時的一個經驗吧。
六、測試(程序截圖)
1.數據輸入及主菜單
2.加法和減法模塊
3.乘法和除法模塊
七、總結
通過本次應用C語言設計一元多項式基本計算程序,使我更加鞏固了C語言程序設計的知識,以前對指針這一點使用是比較模糊,現在通過此次課程設計對指針理解的比較深刻了。而且對于數據結構的相關算法和函數的調用方面知識的加深。本次的課程設計,一方面提高了自己獨立思考處理問題的能力;另一方面使自己再設計開發程序方面有了一定的小經驗和想法,對自己以后學習其他語言程序設計奠定了一定的基礎。
八、指導老師評語及成績
附錄:(課程設計代碼)
#include
float coef;6
int expn;
struct Polynomial *next;} *Polyn,Polynomial;
//Polyn為結點指針類型 void Insert(Polyn p,Polyn h){
if(p->coef==0)free(p);
//系數為0的話釋放結點
else
{
Polyn q1,q2;
q1=h;q2=h->next;
while(q2&&p->expn
{
q1=q2;q2=q2->next;}
if(q2&&p->expn==q2->expn)//將指數相同相合并 {
q2->coef+=p->coef;
free(p);
if(!q2->coef)//系數為0的話釋放結點
{ q1->next=q2->next;free(q2);}
}
else { p->next=q2;q1->next=p;
}//指數為新時將結點插入
} 7
} //建立一個頭指針為head、項數為m的一元多項式 Polyn Create(Polyn head,int m){
int i;
Polyn p;
p=head=(Polyn)malloc(sizeof(struct Polynomial));
head->next=NULL;
for(i=0;i { p=(Polyn)malloc(sizeof(struct Polynomial));//建立新結點以接收數據 printf(“請輸入第%d項的系數與指數:”,i+1); scanf(“%f %d”,&p->coef,&p->expn); Insert(p,head); //調用Insert函數插入結點 } return head;} //銷毀多項式p void Destroy(Polyn p){ Polyn q1,q2; q1=p->next;8 q2=q1->next; while(q1->next) { free(q1); q1=q2;//指針后移 q2=q2->next; } } //輸出多項式p int Print(Polyn P){ Polyn q=P->next; int flag=1;//項數計數器 if(!q)//若多項式為空,輸出0 { putchar('0'); printf(“n”); return; } while(q) { if(q->coef>0&&flag!=1)putchar('+');//系數大于0且不是第一項 9 if(q->coef!=1&&q->coef!=-1)//系數非1或-1的普通情況 { printf(“%g”,q->coef); if(q->expn==1)putchar('X'); else if(q->expn)printf(“X^%d”,q->expn); } else { if(q->coef==1){ if(!q->expn)putchar('1'); else if(q->expn==1)putchar('X'); else printf(“X^%d”,q->expn);} if(q->coef==-1){ if(!q->expn)printf(“-1”); else if(q->expn==1)printf(“-X”); else printf(“-X^%d”,q->expn);} } q=q->next; flag++; } printf(“n”);} int compare(Polyn a,Polyn b){ if(a&&b) { if(!b||a->expn>b->expn)return 1; else if(!a||a->expn else return 0; } else if(!a&&b)return-1;//a多項式已空,但b多項式非空 else return 1;//b多項式已空,但a多項式非空 } //求解并建立多項式a+b,返回其頭指針 Polyn Add(Polyn pa,Polyn pb){ Polyn qa=pa->next; Polyn qb=pb->next; Polyn headc,hc,qc; hc=(Polyn)malloc(sizeof(struct Polynomial));//建立頭結點 11 hc->next=NULL; headc=hc; while(qa||qb){ qc=(Polyn)malloc(sizeof(struct Polynomial)); switch(compare(qa,qb)) { case 1: qc->coef=qa->coef; qc->expn=qa->expn; qa=qa->next; break; case 0: qc->coef=qa->coef+qb->coef; qc->expn=qa->expn; qa=qa->next; qb=qb->next; break; case-1: qc->coef=qb->coef; qc->expn=qb->expn; qb=qb->next; break;12 } if(qc->coef!=0) { qc->next=hc->next; hc->next=qc; hc=qc; } else free(qc);//當相加系數為0時,釋放該結點 } return headc;} //求解并建立多項式a-b,返回其頭指針 Polyn Subtract(Polyn pa,Polyn pb){ Polyn h=pb; Polyn p=pb->next; Polyn pd; while(p)//將pb的系數取反 { p->coef*=-1;p=p->next;} pd=Add(pa,h); for(p=h->next;p;p=p->next) //恢復pb的系數 p->coef*=-1;13 return pd;} //求解并建立多項式a*b,返回其頭指針 Polyn Multiply(Polyn pa,Polyn pb){ Polyn hf,pf; Polyn qa=pa->next; Polyn qb=pb->next; hf=(Polyn)malloc(sizeof(struct Polynomial));//建立頭結點 hf->next=NULL; for(;qa;qa=qa->next) { for(qb=pb->next;qb;qb=qb->next) { pf=(Polyn)malloc(sizeof(struct Polynomial)); pf->coef=qa->coef*qb->coef; pf->expn=qa->expn+qb->expn; Insert(pf,hf);//調用Insert函數以合并指數相同的項 } } return hf;} //求解并建立多項式a/b,返回其頭指針 void Device(Polyn pa,Polyn pb){ Polyn hf,pf,temp1,temp2; Polyn qa=pa->next; Polyn qb=pb->next; hf=(Polyn)malloc(sizeof(struct Polynomial));//建立頭結點,存儲商 hf->next=NULL; pf=(Polyn)malloc(sizeof(struct Polynomial));//建立頭結點,存儲余數 pf->next=NULL; temp1=(Polyn)malloc(sizeof(struct Polynomial)); temp1->next=NULL; temp2=(Polyn)malloc(sizeof(struct Polynomial)); temp2->next=NULL; temp1=Add(temp1,pa); while(qa!=NULL&&qa->expn>=qb->expn) { temp2->next=(Polyn)malloc(sizeof(struct Polynomial)); temp2->next->coef=(qa->coef)/(qb->coef); temp2->next->expn=(qa->expn)-(qb->expn); Insert(temp2->next,hf); pa=Subtract(pa,Multiply(pb,temp2));15 qa=pa->next; temp2->next=NULL; } pf=Subtract(temp1,Multiply(hf,pb)); pb=temp1; printf(“商是:”); Print(hf); printf(“余數是:”); Print(pf);} void main(){ int choose=1;int m,n,flag=0;system(“Color E0”);Polyn pa=0,pb=0,pc,pd,pf;//定義各式的頭指針,pa與pb在使用前付初值NULL printf(“請輸入A(x)的項數:”);scanf(“%d”,&m);printf(“n”);pa=Create(pa,m);//建立多項式A printf(“n”);printf(“請輸入B(x)的項數:”);16 scanf(“%d”,&n);printf(“n”);pb=Create(pb,n);//建立多項式B printf(“n”);printf(“**********************************************n”);printf(“* 多項式操作菜單 printf(”**********************************************n“);printf(”tt 1.輸出操作n“);printf(”tt 2.加法操作n“);printf(”tt 3.減法操作n“);printf(”tt 4.乘法操作n“);printf(”tt 5.除法操作n“);printf(”tt 6.退出操作n“);printf(”**********************************************n“);while(choose){ printf(”執行操作:“); scanf(”%d“,&flag); switch(flag) { case 1: printf(”多項式A(x):“);Print(pa);*n”); printf(“多項式B(x):”);Print(pb); break; case 2: pc=Add(pa,pb); printf(“多項式A(x)+B(x):”);Print(pc); Destroy(pc);break; case 3: pd=Subtract(pa,pb); printf(“多項式A(x)-B(x):”);Print(pd); Destroy(pd);break; case 4: pf=Multiply(pa,pb); printf(“多項式A(x)*B(x):”); Print(pf); Destroy(pf); break; case 5: Device(pa,pb);18 break; case 6: exit(0); break; } } Destroy(pa); Destroy(pb);} 數據結構課程設計 1.赫夫曼編碼器 設計一個利用赫夫曼算法的編碼和譯碼系統,重復地顯示并處理以下項目,直到選擇退出為止。要求: 1)將權值數據存放在數據文件(文件名為data.txt,位于執行程序的當前目錄中) 2)初始化:鍵盤輸入字符集大小26、26個字符和26個權值(統計一篇英文文章中26個字母),建立哈夫曼樹; 3)編碼:利用建好的哈夫曼樹生成哈夫曼編碼; 4)輸出編碼(首先實現屏幕輸出,然后實現文件輸出); 5)界面優化設計。 代碼如下: #include typedef struct HTNode //結構體 { int Weight; char ch;int Parent,Lchild,Rchild;}HTNode;typedef char * * HCode; void Save(int n,HTNode *HT) //把權值保存到文件 { FILE * fp; int i; if((fp=fopen(“data.txt”,“wb”))==NULL) { printf(“cannot open filen”); return; } for(i=0;i if(fwrite(&HT[i].Weight,sizeof(struct HTNode),1,fp)!=1) printf(“file write errorn”); fclose(fp); system(“cls”); printf(“保存成功!”); } void Create_H(int n,int m,HTNode *HT) //建立赫夫曼樹,進行編碼 { int w,k,j;char c;for(k=1;k<=m;k++){ if(k<=n) { printf(“n請輸入權值和字符(用空格隔開): ”); scanf(“%d”,&w); scanf(“ %c”,&c);HT[k].ch=c; HT[k].Weight=w; } else HT[k].Weight=0; HT[k].Parent=HT[k].Lchild=HT[k].Rchild=0;} int p1,p2,w1,w2; for(k=n+1;k<=m;k++){ p1=0;p2=0; w1=32767;w2=32767; for(j=1;j<=k-1;j++) { if(HT[j].Parent==0) { if(HT[j].Weight { w2=w1;p2=p1; w1=HT[j].Weight; p1=j; } else if(HT[j].Weight { w2=HT[j].Weight; p2=j; } } } HT[k].Lchild=p1;HT[k].Rchild=p2;HT[k].Weight=HT[p1].Weight+HT[p2].Weight; HT[p1].Parent=k;HT[p2].Parent=k; } printf(“輸入成功!”);} void Coding_H(int n,HTNode *HT) //對結點進行譯碼 { int k,sp,fp,p;char *cd;HCode HC; HC=(HCode)malloc((n+1)*sizeof(char *)); cd=(char *)malloc(n*sizeof(char));cd[n-1]='
主站蜘蛛池模板:
午夜精品影视国产一区在线麻豆|
欧美老妇人与禽交|
人妻无码av中文系列久|
久久久橹橹橹久久久久|
精品久久久久久777米琪桃花|
国语精品一区二区三区|
菠萝菠萝蜜午夜视频在线播放观看|
在线观看老湿视频福利|
亚洲偷自拍国综合色帝国|
艳妇荡女欲乱双飞两中年熟妇|
午夜无码一区二区三区在线观看|
久久视频在线观看精品|
一二三四视频社区在线|
欧美丰满一区二区免费视频|
欲色影视天天一区二区三区色香欲|
92国产精品午夜免费福利视频|
国产精品99久久久精品无码|
久久zyz资源站无码中文动漫|
少妇被躁爽到高潮无码文|
无码一区二区波多野结衣播放搜索|
综合久久综合久久88色鬼|
九九99热久久精品在线6|
国产免费观看久久黄av片|
好紧好爽好湿别拔出来视频男男|
亚洲理论在线中文字幕观看|
女人被狂躁的高潮免费视频|
国产熟妇与子伦hd|
99国产揄拍国产精品人妻|
免费无码毛片一区二区三区a片|
狠狠人妻久久久久久综合|
疯狂迎合进入强壮公的视频|
久久综合九色综合97网|
妺妺窝人体色www看人体|
国产成人亚洲综合无码8|
亚洲欧洲日韩欧美网站|
国内精品伊人久久久久777|
久久久噜噜噜久久熟女|
国产精品日韩欧美一区二区三区|
国产精品久久久久国产a级|
国产中老年妇女精品|
2024av天堂手机在线观看|
第三篇:數據結構課程設計