報告是指向上級機關匯報本單位、本部門、本地區(qū)工作情況、做法、經驗以及問題的報告,報告書寫有哪些要求呢?我們怎樣才能寫好一篇報告呢?這里我整理了一些優(yōu)秀的報告范文,希望對大家有所幫助,下面我們就來了解一下吧。
數據結構實驗報告線性表 數據結構實驗報告總結與心得篇一
實驗(實習)名稱數據結構實驗(實習)日期 2011-11-2得分指導教師周素萍
系公共管理系專業(yè)信息管理與信息系統(tǒng)年級10級班次1姓名常玲學號2010230700
3實驗一順序表的基本操作及c語言實現
【實驗目的】
1、順序表的基本操作及 c 語言實現
【實驗要求】
1、用 c 語言建立自己的線性表結構的程序庫,實現順序表的基本操作。
2、對線性表表示的集合,集合數據由用戶從鍵盤輸入(數據類型為整型),建立相應的順序表,且使得數據按從小到大的順序存放,將兩個集合的并的結果存儲在一個新的線性表集合中,并輸出。
【實驗內容】
1、根據教材定義的順序表機構,用 c 語言實現順序表結構的創(chuàng)建、插入、刪除、查找等操作;
2、利用上述順序表操作實現如下程序:建立兩個順序表表示的集合(集合中無重
復的元素),并求這樣的兩個集合的并。
【實驗結果】
[實驗數據、結果、遇到的問題及解決]
一. status insertorderlist(sqlist &va,elemtype x)
{
}
二. status deletek(sqlist &a,int i,int k)
{//在非遞減的順序表va中插入元素x并使其仍成為順序表的算法 int i;if(v==ze)return(overflow);for(i=v;i>0,x
}
//注意i的編號從0開始 int j;if(i<0||i>-1||k<0||k>-i)return infeasible;for(j=0;j<=k;j++)[j+i]=[j+i+k];=-k;return ok;
三.// 將合并逆置后的結果放在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的前驅指針 // 保存pb的前驅指針 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;//將當前最小結點插入a表表頭 a->next=qb;qa=pa;pa=pa->next;qa->next=a->next;//將當前最小結點插入a表表頭 a->next=qa;
}
} pb=b;free(pb);return ok;qb=pb;pb=pb->next;qb->next=a->next;a->next=qb;
順序表就是把線性表的元素存儲在數組中,元素之間的關系直接通過相鄰元素的位置來表達。
優(yōu)點:簡單,數據元素的提取速度快;
缺點:(1)靜態(tài)存儲,無法預知問題規(guī)模的大小,可能空間不足,或浪費存儲空間;(2)插入元素和刪除元素時間復雜度高——o(n)
求兩個集合的并集
該算法是求兩個集合s1和s2的并集,并將結果存入s引用參數所表示的集合中帶回。首先把s1集合復制到s中,然后把s2中的每個元素依次插入到集合s中,當然重復的元素不應該被插入,最后在s中就得到了s1和s2的并集,也就是在s所對應的實際參數集合中得到并集。
數據結構實驗報告線性表 數據結構實驗報告總結與心得篇二
河南省高等教育自學考試
實 驗 報 告 冊
計算機及應用專業(yè)(本科段)
《數據結構》
姓名周東偉準考證號010512201008所屬地市鄭州實驗地點河南職業(yè)技術學院實驗日期2014-3-18實驗總成績指導教師簽名實驗單位(實驗室)意見:主考院校審核意見:
河南科技大學自學考試辦公室
數據結構實驗報告線性表 數據結構實驗報告總結與心得篇三
注意:實驗結束后提交一份實驗報告電子文檔
電子文檔命名為“學號+姓名”,如:e01214058宋思怡
《數據結構》實驗報告
(一)學號:姓名:專業(yè)年級:
實驗名稱:線性表
實驗日期:2014年4月14日
實驗目的:
1、熟悉線性表的定義及其順序和鏈式存儲結構;
2、熟練掌握線性表在順序存儲結構上實現基本操作的方法;
3、熟練掌握在各種鏈表結構中實現線性表基本操作的方法;
4、掌握用 c/c++語言調試程序的基本方法。
實驗內容:
一、編寫程序實現順序表的各種基本運算,并在此基礎上設計一個主程序完成如下功能:
(1)初始化順序表l;
(2)依次在l尾部插入元素-1,21,13,24,8;
(3)輸出順序表l;
(4)輸出順序表l長度;
(5)判斷順序表l是否為空;
(6)輸出順序表l的第3個元素;
(7)輸出元素24的位置;
(8)在l的第4個元素前插入元素0;
(9)輸出順序表l;
(10)刪除l的第5個元素;
(11)輸出順序表l。
源代碼
調試分析(給出運行結果界面)
二、編寫程序實現單鏈表的各種基本運算,并在此基礎上設計一個主程序完成如下功能:
????
????
小結或討論:
(1)實驗中遇到的問題和解決方法
(2)實驗中沒有解決的問題
(3)體會和提高
數據結構實驗報告線性表 數據結構實驗報告總結與心得篇四
數 據 結 構 實 驗 報 告
1.問題描述
為某個單位建立一個員工通訊錄管理系統(tǒng),可以方便地查詢每一個員工的辦公室電話號碼、手機號碼及電子郵箱。2.設計分析
在本設計中,整個通訊錄可以采用順序表或鏈表方式存儲。其功能包括通訊錄鏈表的建立、員工通訊信息的查詢、修改、插入與刪除以及整個通訊錄表的輸出。3.員工通訊信息的結構類型定義和通訊錄鏈表的結點類型
typedef struct { char num[5];/*員工編號*/ char name[8];/*員工姓名*/ char phone[9];/*辦公室電話號碼*/ char call[12];/*手機號碼*/ }datatype;/*員工通訊信息的結構類型*/ typedef struct node { datatype data;/*結點的數據域*/ struct node *next;/*結點的指針域*/ }listnode,*linklist;/*通訊錄鏈表的結構類型*/ 4.實驗源代碼
// : 定義控制臺應用程序的入口點。// //#include “stdafx.h” #include“stdio.h” #include “stdlib.h” # include
#include
#include
using namespace std;#define list_init_size 100 #define listincrement 10 #define true 1 #define false 0 #define ok 1 #define error 0 typedef intstatus;typedef struct { /*員工通訊信息的結構類型定義*/
char num[5];/*員工編號*/
char name[8];
/*員工姓名*/ char phone[9];
/*辦公室電話號碼*/
char call[12];
/*手機號碼*/
char mail[15];
/*郵箱*/ }datatype;/*通訊錄單鏈表的結點類型*/ typedef struct node {
datatype data;
/*結點的數據域*/
struct node *next;
/*結點的指針域*/ }lnode, *linklist;void createlist(linklist &l){//逆位序輸入n個元素的值,建立帶表頭結點的單鏈線性表l
linklist p;
int i,n;
l =(linklist)malloc(sizeof(lnode));
l->next = null;
cout <<“請輸入創(chuàng)建員工的通訊信息的個數:”;
cin >> n;
for(i = 0;i
p =(linklist)malloc(sizeof(lnode));
cout <<“
請輸入員工信息”<
cout <<“
員工編號:”;
cin>> p->;
cout <<“
員工姓名:”;
cin >> p->;
cout <<“辦公室電話號碼:”;
cin >> p->;
cout <<“
手機號碼:”;
cin >> p->;
cout <<“
員工郵箱:”;
cin >> p->;
cout <<“================================”<< endl;
p->next = l->next;
l->next = p;
} } void initlist(linklist &l){//初始化線性表
l =(linklist)malloc(sizeof(lnode));
l->next = null;} void destroylist(linklist &l){//銷毀線性表
linklist p, q;
p = l;
q = p->next;
while(q!= null)
{ free(p);
} } int listempty(linklist &l){//判斷線性表是否為空
if(l->next == null)
return true;
else
return false;} int listlength(linklist &l){//求鏈表的長度
linklist p = l;
int c = 0;
while(p->next!= null){
c++;
p = p->next;
}
return(c);} void getelem(linklist &l){//取鏈表第i個數據元素
linklist p = l->next;
string s;
cout <<“輸入員工的編號或名字:”;
cin >> s;
while(p!= null)//根據相關信息,查找員工。
{
if(p-> == s || p-> == s || p-> == s || p-> == s || p-> == s)
break;
p = p->next;
}
if(!p)
cout <<“查無此人!”<< endl;
else{
cout <<“
員工信息”<< endl;
cout <<“
員工編號:”<< p-> << endl;
cout <<“
員工姓名:”<< p-> << endl;
cout <<“辦公室電話號碼:”<< p-> << endl;
cout <<“
手機號碼:”<< p-> << endl;
cout <<“
員工郵箱:”<< p-> << endl;
cout <<“================================”<< endl;
} } void reviselist(linklist &l)//修改信息 {
linklist p = l->next;
char j[20];
string s;
int i;
cout <<“輸入員工的編號或名字:”;
cin >> s;
while(p!= null){//根據相關信息,查找員工。
if(p-> == s || p-> == s || p-> == s || p-> == s || p-> == s)
break;
p = p->next;
}
if(!p)
cout <<“查無此人!”<< endl;
else
{
cout <<“n想修改什么信息?_1-編號 2-姓名 3-辦公室電話號碼 4-手機號碼 5-郵箱”<< endl;
cin >> i;
cout <<“想修改成什么?”<< endl;
cin >> j;
switch(i){
case 1:strcpy(p->, j);break;
case 2:strcpy(p->, j);break;
case 3:strcpy(p->, j);break;
case 4:strcpy(p->, j);break;
case 5:strcpy(p->, j);break;
default: cout <<“輸入錯誤,”<< endl;
system(“pause”);
}
cout <<“修改完畢!”;
system(“pause”);
return;
} } void listdelete(linklist &l)//刪除第i個元素 {
linklist p, q;
int j = 0,i;p = l;
cout <<“請輸入你要刪除第幾個員工的信息:”;
cin >> i;
while(p->next && j < i1)//刪除位置不合理
cout <<“刪除位置不合理”<< endl;
q = p->next;
p->next = q->next;//刪除并釋放結點
free(q);} void listinsert(linklist &l){
linklist s, p = l;
s =(linklist)malloc(sizeof(lnode));
cout <<“
請輸入員工信息”<< endl;
cout <<“
員工編號:”;
cin >> s->;
cout <<“
員工姓名:”;
cin >> s->;
cout <<“辦公室電話號碼:”;
cin >> s->;
cout <<“
手機號碼:”;
cin >> s->;
cout <<“
員工郵箱:”;
cin >> s->;
cout <<“================================”<< endl;
s->next = p->next;
p->next = s;}
void printlist(linklist &l)//打印線性表 {
linklist p = l->next;
int i = 1;
if(p == null)
cout <<“通訊錄為空!”<< endl;
while(p!= null)
{
cout <<“第 ”<
cout <<“
員工編號:”<< p-> << endl;
cout <<“
員工姓名:”<< p-> << endl;
cout <<“辦公室電話號碼:”<< p-> << endl;
cout <<“
手機號碼:”<< p-> << endl;
cout <<“
員工郵箱:”<< p-> << endl;
cout <<“==============================”<< endl;
p = l;
cout <<“請輸入你要刪除第幾個員工的信息:”;
cin >> i;
while(p->next && j < i1)//刪除位置不合理
cout <<“刪除位置不合理”<< endl;
q = p->next;
p->next = q->next;//刪除并釋放結點
free(q);} void listinsert(linklist &l){
linklist s, p = l;
s =(linklist)malloc(sizeof(lnode));
cout <<“
請輸入員工信息”<< endl;
cout <<“
員工編號:”;
cin >> s->;
cout <<“
員工姓名:”;
cin >> s->;
cout <<“辦公室電話號碼:”;
cin >> s->;
cout <<“
手機號碼:”;
cin >> s->;
cout <<“
員工郵箱:”;
cin >> s->;
cout <<“================================”<< endl;
s->next = p->next;
p->next = s;}
void printlist(linklist &l)//打印線性表 {
linklist p = l->next;
int i = 1;
if(p == null)
cout <<“通訊錄為空!”<< endl;
while(p!= null)
{
cout <<“第 ”<
cout <<“
員工編號:”<< p-> << endl;
cout <<“
員工姓名:”<< p-> << endl;
cout <<“辦公室電話號碼:”<< p-> << endl;
cout <<“
手機號碼:”<< p-> << endl;
cout <<“
員工郵箱:”<< p-> << endl;
cout <<“==============================”<< endl;break;
case 4:
//添加
listinsert(l);
cout <<“添加信息成功!”;
system(“pause”);
break;
case 5:
printlist(l);
listdelete(l);
cout <<“刪除信息成功!”;
system(“pause”);
break;//輸出全部信息
case 6:
printlist(l);
system(“pause”);
break;
case 7:
cout <<“該通訊錄共有 ”<< listlength(l)<<“ 員工信息!”<< endl;;
system(“pause”);
break;
default:
cout <<“輸入錯誤!”<< endl;
system(“pause”);
}
} while(in!= 0);} 5.實驗截圖.
數據結構實驗報告線性表 數據結構實驗報告總結與心得篇五
實驗報告4 排序
一、實驗目的
1、掌握常用的排序方法,并掌握用高級語言實現排序算法的方法。
2、深刻理解排序的定義和各種排序方法的特點,并能加以靈活應用。
3、了解各種方法的排序過程及其依據的原則,并掌握各種排序方法的時間復雜度的分析方法。
二、實驗要求及內容
要求編寫的程序所能實現的功能包括:
1、從鍵盤輸入要排序的一組元素的總個數
2、從鍵盤依次輸入要排序的元素值
3、對輸入的元素進行快速排序
4、對輸入的元素進行折半插入排序
三、實驗代碼及相關注釋
#include
using namespace std;#include “malloc.h”
typedef struct { int key;}redtype;typedef struct { redtype r[100];int length;}sqlist;
//1 快速排序的結構體
typedef struct {
int data[100];
int last;}sequenlist;//2 折半插入排序的結構體
int partition(sqlist &l, int low, int high)
//1 尋找基準
{
l.r[0]=l.r[low];//子表的第一個記錄作基準對象
int pivotkey = l.r[low].key;//基準對象關鍵字 while(low
while(low
= pivotkey)--high;
l.r[low] = l.r[high];//小于基準對象的移到區(qū)間的左側while(low
l.r[high] = l.r[low];//大于基準對象的移到區(qū)間的右側 }
l.r[low] = l.r[0];return low;}
void quicksort(sqlist &l, int low, int high)
//1 快速排序 { //在序列l(wèi)ow-high中遞歸地進行快速排序
if(low < high)
{
int pivotloc= partition(l, low, high);
//尋找基準
quicksort(l, low, pivotloc-1);//對左序列同樣遞歸處理
quicksort(l, pivotloc+1, high);//對右序列同樣遞歸處理
} }
sequenlist *sqlset()
//2 輸入要折半插入排序的一組元素
{
sequenlist *l;
int i;
l=(sequenlist *)malloc(sizeof(sequenlist));
l->last=0;
cout<<“請輸入要排序的所有元素的總個數:”;
cin>>i;
cout<
cout<<“請依次輸入所有元素的值:”;
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;//插入點在前半區(qū)else
low=mid+1;//插入點在后半區(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<<“請選擇功能(1.快速排序 2.折半插入排序 3.退出程序):”;int m;cin>>m;cout<
if(m==1){ sqlist l;int n;cout<<“請輸入要排序的所有元素的總個數:”;cin>>n;cout<
cin>>l.r[i].key;
} cout<
quicksort(l,1,);
for(int j=1;j<=;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<
四、重要函數功能說明
1、sequenlist *sqlset()
輸入要折半插入排序的一組元素
2、int partition(sqlist &l, int low, int high)
尋找快速排序的基準
3、void quicksort(sqlist &l, int low, int high)
快速排序
4、middlesort(sequenlist *l)
折半插入排序
五、程序運行結果
下圖僅為分別排序一次,可多次排序,后面有相關截圖:
六、實驗中遇到的問題、解決及體會
1、起初編寫快速排序的程序時,我是完全按照老師ppt上的算法敲上去的,然后建立了一個sqlist的結構體,調試運行時出現錯誤,仔細查看才意識到partition函數中l(wèi)中應該包含元素key,而我建立結構體時沒有注意,然后我將key這個元素補充進去,繼續(xù)調試,又出現錯誤,提示我partition沒有定義,我就覺得很奇怪,我明明已經寫了函數定義,為什么會這樣,當我又回過頭來閱讀程序時,我發(fā)現quicksort函數中調用了partition函數,但是我的partition函數的定義在quicksort函數的后面,于是我將partition函數放到了quicksort函數的前面,再次調試運行,就可以正常運行,得出結果了。這讓我懂得,編程一定要認真仔細,不可大意馬虎,否則又會花很多時間回過頭來檢查修改程序,得不償失。
運行程序錯誤截圖:
2、本來我是編寫了兩個程序,分別實現快速排序和折半插入排序的功能,但我后來想我是否可以將其合二為一,于是我想到用if選擇語句用來實現不同的功能,從鍵盤輸入功能選項m,if(m==1),可以進行快速排序,if(m==2),可以進行折半插入排序,于是我繼續(xù)思考,我是否可以在一次運行程序中,多次對含有不同元素的序列進行排序,于是我用了goto語句,每次排序一次后,自動循環(huán)到選擇語句,當不需要在排序的時候,可以從鍵盤輸入3,退出程序,這樣一來,程序變得更加實用和清晰明朗。這讓我懂得,想要編出好的程序,要善于思考,在實現所需功能的前提下,多想問題,看是否能使程序更加實用簡便。
修改程序前兩個運行結果截圖
(兩個程序,調試運行兩次,每次只能進行一次排序)
1、快速排序程序運行結果截圖:
2、折半插入排序程序結果截圖:
程序重要模塊修改截圖:
修改程序后運行截圖:
(一個程序,調試運行一次,可多次進行不同序列的不同排序)
【本文地址:http://mlvmservice.com/zuowen/1577027.html】