数据结构编程实验
Posted bestefforts
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据结构编程实验相关的知识,希望对你有一定的参考价值。
实验一 动态链表的设计与应用
1.随机产生或键盘输入一组元素,建立一个带头结点的单向链表(无序)。
2.遍历单向链表。
3.把单向链表中元素逆置(不允许申请新的结点空间)。
4.在单向链表中删除所有的偶数元素结点。
5.编写在非递减有序链表中插入一个元素使链表元素仍有序的函数,并利用该函数建立一个非递减有序单向链表。
6.利用算法5建立两个非递减有序单向链表,然后合并成一个非递增链表。
7.利用算法5建立两个非递减有序单向链表,然后合并成一个非递减链表。
8.利用算法1建立的链表,实现将其分解成两个链表,其中一个全部为奇数,另一个全部为偶数(尽量利用已知的存储空间)。
* 9.采用单向链表实现一元多项式的存储并实现两个多项式相加并输出结果。
10.在主函数中设计一个简单的菜单,分别调试上述算法。
*11.综合训练:利用单向循环链表实现一个班级学生信息管理(数据录入、插入、删除、排序、查找等,并能够实现将数据存储到文件中)
1 #include <bits/stdc++.h> 2 using namespace std; 3 4 typedef int ElemType;//元素类型 5 typedef struct LNode{ 6 ElemType data; 7 struct LNode *next; 8 }LNode,*LinkList; 9 //声明 10 LinkList Ran_createNode(int n); 11 LinkList createNode(int n); 12 void show(LinkList head); 13 LinkList updown(LinkList head); 14 LinkList erase_even(LinkList head); 15 LinkList head,head1,head2; 16 void insert_lower_bound(LNode *head,ElemType data); 17 LinkList creat_lower_bound(int n); 18 LinkList creatlow(int x1,int x2); 19 LinkList creathigh(int x1,int x2); 20 void fenjie(int n,LinkList head1,LinkList head2); 21 int menu(); 22 void print(LinkList head,int n); 23 LinkList duoxiang(int x1,int x2); 24 25 int main(){ 26 while(menu()); 27 } 28 29 //0.单链表的初始化 30 LinkList LinkedListInit() 31 { 32 LinkList L; 33 L = (LinkList)malloc(sizeof(LNode)); //申请结点空间 34 if(L == NULL) //判断是否有足够的内存空间 35 printf("申请内存空间失败/n"); 36 L->next = NULL; //将next设置为NULL,初始长度为0的单链表 37 return L; 38 } 39 //1.1 随机产生长度为n的链表 40 LinkList Ran_createNode(int n){ 41 LinkList L; //头指针 42 L=(LinkList)malloc(sizeof(LNode)); 43 L->next=NULL; //初始化空链表 44 LinkList r; //新指针 45 r=L; 46 while(n--){ 47 LinkList p; 48 p=(LinkList)malloc(sizeof(LNode)); 49 p->data=rand()%1000; //随机生成下一个 50 if(rand()%2==0)p->data=-p->data; 51 r->next=p; 52 r=p; 53 } 54 r->next=NULL; 55 return L; 56 } 57 //1.2 按输入生成长度为n的链表 58 LinkList createNode(int n){ 59 LinkList L; //头指针 60 L=(LinkList)malloc(sizeof(LNode)); 61 L->next=NULL; //初始化空链表 62 LinkList r; //新指针 63 r=L; 64 ElemType x; 65 while(n--){ 66 LinkList p; 67 cin >> x; 68 p=(LinkList)malloc(sizeof(LNode)); 69 p->data=x; //随机生成下一个 70 r->next=p; 71 r=p; 72 } 73 r->next=NULL; 74 return L; 75 } 76 //2.输出链表 77 void show(LinkList head){ 78 LinkList p; 79 for(p=head->next;p!=NULL;p=p->next){ 80 printf("%d\t",p->data); 81 } 82 printf("\n"); 83 } 84 //3.逆置 85 LinkList updown(LinkList head){ 86 LinkList p1,p2,p3; 87 p1=head->next; 88 p2=NULL; 89 head->next=NULL; 90 while(p1!=NULL){ 91 p3=p1->next; 92 p1->next=p2; 93 p2=p1; 94 p1=p3; 95 } 96 head->next=p2; 97 return head; 98 } 99 //4.删除所有偶数节点 100 LinkList erase_even(LinkList head){ 101 LinkList p1; 102 for(p1=head;p1->next!=NULL;p1=p1->next){ 103 while((p1->next->data)%2==0){ 104 p1->next=p1->next->next; 105 if(p1->next==NULL) 106 break; 107 } 108 if(p1->next==NULL) 109 break; 110 } 111 return head; 112 } 113 //5.非递减有序插入 114 void insert_lower_bound(LNode *head,ElemType data){ 115 LinkList p,pnew; 116 pnew=new LNode; 117 pnew->data=data; 118 int flag=0; 119 for(p=head;p->next!=NULL;p=p->next){ 120 if(p->next->data>=data){ 121 pnew->next=p->next; 122 p->next=pnew; 123 flag=1; 124 break; 125 } 126 } 127 if(flag==0){ 128 pnew->next=NULL; 129 p->next=pnew; 130 } 131 } 132 //5.建立一个非递减有序单向链表。 133 LinkList creat_lower_bound(int n){ 134 LinkList head=LinkedListInit(); 135 while(n--){ 136 insert_lower_bound(head,rand()%1000); 137 } 138 show(head); 139 return head; 140 } 141 //6.合并生成非递增 随机 142 LinkList creatlow(int x1,int x2){ 143 printf("链表1:\n"); 144 LinkList head1=creat_lower_bound(x1); 145 printf("链表2:\n"); 146 LinkList head2=creat_lower_bound(x2); 147 LinkList p; 148 for(p=head2->next;p!=NULL;p=p->next){ 149 insert_lower_bound(head1,p->data); 150 } 151 printf("合并后非递增链表如下:\n"); 152 updown(head1); 153 show(head1); 154 return head1; 155 } 156 //7.合并生成非递减 随机 157 LinkList creathigh(int x1,int x2){ 158 printf("链表1:\n"); 159 LinkList head1=creat_lower_bound(x1); 160 printf("链表2:\n"); 161 LinkList head2=creat_lower_bound(x2); 162 LinkList p; 163 for(p=head2->next;p!=NULL;p=p->next){ 164 insert_lower_bound(head1,p->data); 165 } 166 printf("合并后非递减链表如下:\n"); 167 show(head1); 168 return head1; 169 } 170 //8.分解为奇数偶数两个链表 随机 171 void fenjie(int n,LinkList head1,LinkList head2){ 172 head1=LinkedListInit(); 173 head2=LinkedListInit(); 174 LinkList head=Ran_createNode(n); 175 printf("链表如下:\n"); 176 show(head); 177 LinkList p,tmp,p1,p2; 178 p1=head1;p2=head2; 179 for(p=head->next;p!=NULL;p=p->next){ 180 tmp=new LNode; 181 tmp->data=p->data; 182 if((tmp->data)%2==0){ 183 p2->next=tmp; 184 p2=tmp; 185 } 186 else{ 187 p1->next=tmp; 188 p1=tmp; 189 } 190 } 191 p1->next=NULL;p2->next=NULL; 192 printf("奇数链表如下:\n"); 193 show(head1); 194 printf("偶数链表如下:\n"); 195 show(head2); 196 } 197 //10.菜单 198 int menu(){ 199 srand((unsigned)time(NULL)); 200 printf("\n------------------------------------------------------------------------------\n"); 201 printf("请输入需要进行的操作:\n"); 202 printf("0.随机产生元素建立一个带头结点的单向链表(无序)。\n"); 203 printf("1.键盘输入一组元素,建立一个带头结点的单向链表(无序)。\n"); 204 printf("2.输出单向链表的元素。\n"); 205 printf("3.把单向链表中元素逆置。\n"); 206 printf("4.在单向链表中删除所有的偶数元素结点。\n"); 207 printf("5.建立一个非递减有序单向链表。\n"); 208 printf("6.建立两个非递减有序单向链表,然后合并成一个非递增链表。\n"); 209 printf("7.建立两个非递减有序单向链表,然后合并成一个非递减链表。\n"); 210 printf("8.建立一个链表,实现将其分解成两个链表,其中一个全部为奇数,另一个全部为偶数。\n"); 211 printf("9.采用单向链表实现一元多项式的存储并实现两个多项式相加并输出结果。\n"); 212 printf("其他.退出\n"); 213 printf("------------------------------------------------------------------------------\n"); 214 int x,x1,x2; 215 cin >> x; 216 int n; 217 switch(x){ 218 case 0:printf("请输入n以建立长度为n的链表\n");cin >> n;head=Ran_createNode(n);show(head);break; 219 case 1:printf("请输入n以建立长度为n的链表\n");cin >> n;printf("接下来请输入n个数以建立长度为n的链表\n");head=createNode(n);show(head);break; 220 case 2:show(head);break; 221 case 3:head=updown(head);show(head);break; 222 case 4:head=erase_even(head);show(head);break; 223 case 5:printf("请输入n以建立长度为n的链表\n");cin >> n;head=creat_lower_bound(n);break; 224 case 6:printf("请输入两个数x1,x2以建立建立两个非递增有序单向链表\n");cin >> x1 >>x2;creatlow(x1,x2);break; 225 case 7:printf("请输入两个数x1,x2以建立建立两个非递减有序单向链表\n");cin >> x1 >>x2;creathigh(x1,x2);break; 226 case 8:printf("请输入n以建立长度为n的链表\n");cin >> n;fenjie(n,head1,head2);break; 227 case 9:printf("请输入两个数x1,x2以建立两个一元多项式\n");cin >> x1 >> x2;duoxiang(x1,x2);break; 228 229 default:return 0; 230 } 231 return 1; 232 } 233 234 235 236 237 238 239 //输出多项式 240 void print(LinkList head,int n) 241 { 242 int flag=0; 243 LinkList p; 244 for(p=head->next;p!=NULL;p=p->next,n--){ 245 if(p->data==0)continue; 246 flag=1; 247 if(p!=head->next&&p->data>0) 248 cout << ‘+‘; 249 if(n==0) 250 cout << p->data; 251 else{ 252 if(p->data==1) 253 cout <<‘x‘; 254 else if(p->data==-1) 255 cout << "-x"; 256 else 257 cout << p->data <<‘x‘; 258 if(n!=1) 259 cout << ‘^‘ << n; 260 } 261 } 262 if(!flag){ 263 cout << 0 ; 264 } 265 cout <<endl; 266 } 267 //9.多项式 268 LinkList duoxiang(int x1,int x2) 269 { 270 LinkList head1=Ran_createNode(x1); 271 printf("A: "); 272 print(head1,x1); 273 LinkList head2=Ran_createNode(x2); 274 printf("B: "); 275 print(head2,x2); 276 LinkList p,p1; 277 int n=max(x1,x2); 278 if(x1<x2){ 279 p1=head1->next; 280 for(p=head2->next;p!=NULL;p=p->next,x2--){ 281 if(x1==x2){ 282 p->data=p1->data+p->data; 283 x1--; 284 } 285 } 286 printf("A+B: "); 287 print(head2,n); 288 return head2; 289 } 290 else{ 291 p1=head2->next; 292 for(p=head1->next;p!=NULL;p=p->next,x1--){ 293 if(x1==x2){ 294 p->data=p1->data+p->data; 295 x2--; 296 } 297 } 298 printf("A+B: "); 299 print(head1,n); 300 return head1; 301 } 302 }
实验二 栈的设计、实现及应用
1.采用链式存储实现栈的初始化、入栈、出栈操作。
2.采用顺序存储实现栈的初始化、入栈、出栈操作。
3.采用链式存储实现队列的初始化、入队、出队操作。
4.采用顺序存储实现循环队列的初始化、入队、出队操作。
5.在主函数中设计一个简单的菜单,分别测试上述算法。
*6.综合训练:1)利用栈实现表达式求值算法。
2)利用栈实现迷宫求解。
1 #include <iostream> 2 #include <cstdio> 3 #include <string> 4 #include <cstring> 5 using namespace std; 6 #define MAX 100 //栈的最大值 7 8 typedef int ElemType; 9 //节点 10 class Node{ 11 public: 12 ElemType data; 13 Node *next; 14 }; 15 //基于链表实现的栈 16 class Stack{ 17 public: 18 //构造器 19 Stack(){ 20 Stack_top=NULL; 21 } 22 //出栈 23 void pop(){ 24 if(Stack_top!=NULL){ 25 Node *p=Stack_top; 26 Stack_top=Stack_top->next; 27 delete p; 28 } 29 } 30 //入栈 31 void push(ElemType x){ 32 Node *p=new Node; 33 p->next=Stack_top; 34 p->data=x; 35 Stack_top=p; 36 } 37 //得到栈末数据 38 ElemType top(){ 39 if(Stack_top) 40 return Stack_top->data; 41 else 42 return 0; 43 } 44 //判栈空 45 bool isEmpty(){ 46 return Stack_top==NULL; 47 } 48 private: 49 //栈顶指针 50 Node *Stack_top; 51 }; 52 //基于链表实现的队列 53 class Queue{ 54 public: 55 //构造器 56 Queue(){ 57 Queue_top=new Node; 58 Queue_end=Queue_top; 59 Queue_top->next=NULL; 60 Queue_top->data=0; 61 num=0; 62 } 63 //出队 64 void pop(){ 65 if(num){ 66 Node *p=Queue_top; 67 Queue_top=Queue_top->next; 68 delete p; 69 num--; 70 } 71 } 72 //入队 73 void push(ElemType x){ 74 Node *p=new Node; 75 p->data=x; 76 Queue_end->next=p; 77 Queue_end=p; 78 Queue_end->next=NULL; 79 if(num==0){ 80 Queue_top=Queue_top->next; 81 } 82 num++; 83 } 84 //得到队首数据 85 ElemType top(){ 86 if(num) 87 return Queue_top->data; 88 else 89 return 0; 90 } 91 //判队空 92 bool isEmpty(){ 93 return num!=0; 94 } 95 private: 96 //队首指针 97 Node *Queue_top; 98 //队末指针 99 Node *Queue_end; 100 int num; 101 }; 102 103 //顺序栈 104 typedef struct 105 { 106 ElemType *base; 107 int top; 108 }SqStack; 109 //顺序队列 110 typedef struct 111 { 112 ElemType *base; 113 int fron,rear; 114 }SqQueue; 115 //顺序栈初始化 116 void st_init(SqStack &st){ 117 st.base=new ElemType[MAX]; 118 st.top=-1; 119 } 120 //顺序栈出栈 121 bool st_pop(SqStack &st){ 122 if(st.top<0){ 123 return false; 124 } 125 st.top--; 126 return true; 127 } 128 //顺序栈入栈 129 bool st_push(SqStack &st,ElemType x){ 130 if(st.top>=MAX-1){ 131 return false; 132 } 133 st.top++; 134 st.base[st.top]=x; 135 return true; 136 } 137 //得到栈顶元素 138 ElemType st_top(SqStack &st){ 139 return st.base[st.top]; 140 } 141 142 //顺序队列初始化 143 void Q_init(SqQueue &q){ 144 q.base=new ElemType[MAX]; 145 q.fron=q.rear=0; 146 } 147 //顺序队列出队 148 bool Q_pop(SqQueue &q){ 149 if(q.fron==q.rear){ 150 return false; 151 } 152 q.fron=(q.fron+1)%MAX; 153 return true; 154 } 155 //顺序队列入队 156 bool Q_push(SqQueue &q,ElemType x){ 157 if((q.fron-q.rear+MAX)%MAX==1){ 158 return false; 159 } 160 q.base[q.rear]=x; 161 q.rear=(q.rear+1)%MAX; 162 return true; 163 } 164 165 //得到队首元素 166 ElemType Q_top(SqQueue &q){ 167 return q.base[q.fron]; 168 } 169 170 //后缀表达式求值 171 int solve(char* x) 172 { 173 Stack st; 174 int ans=0,flag=0,i; 175 for(i=0;i<strlen(x);i++) 176 { 177 if(x[i]>=‘0‘&&x[i]<=‘9‘) 178 { 179 ans=ans*10+x[i]-‘0‘; 180 flag=1; 181 } 182 else 183 { 184 if(flag) 185 { 186 st.push(ans); 187 flag=0; 188 } 189 ans=0; 190 } 191 if(x[i]==‘+‘) 192 { 193 int a=st.top(); 194 st.pop(); 195 int b=st.top(); 196 st.pop(); 197 st.push(a+b); 198 } 199 else if(x[i]==‘-‘) 200 { 201 int a=st.top(); 202 st.pop(); 203 int b=st.top(); 204 st.pop(); 205 st.push(b-a); 206 } 207 else if(x[i]==‘*‘) 208 { 209 int a=st.top(); 210 st.pop(); 211 int b=st.top(); 212 st.pop(); 213 st.push(a*b); 214 } 215 else if(x[i]==‘/‘) 216 { 217 int a=st.top(); 218 st.pop(); 219 int b=st.top(); 220 st.pop(); 221 st.push(b/a); 222 } 223 } 224 return st.top(); 225 226 } 227 //中缀转后缀 228 void trans(char* x,char *y) 229 { 230 Stack st; 231 int ans=0,flag=0,i,j=0; 232 for(i=0;i<strlen(x);i++) 233 { 234 while(x[i]>=‘0‘&&x[i]<=‘9‘) 235 { 236 ans=ans*10+x[i]-‘0‘; 237 flag=1; 238 i++; 239 } 240 if(flag) 241 { 242 Stack tmp; 243 while(ans>0) 244 { 245 tmp.push(ans%10); 246 ans/=10; 247 } 248 while(!tmp.isEmpty()) 249 { 250 y[j++]=tmp.top()+‘0‘; 251 tmp.pop(); 252 } 253 y[j++]=‘ ‘; 254 } 255 if(x[i]==‘*‘||x[i]==‘/‘||x[i]==‘(‘) 256 { 257 st.push(x[i]); 258 } 259 260 else if(x[i]==‘+‘||x[i]==‘-‘) 261 { 262 if(st.top()==‘*‘||st.top()==‘/‘) 263 { 264 while(!st.isEmpty()&&st.top()!=‘(‘) 265 { 266 y[j++]=st.top(); 267 st.pop(); 268 } 269 st.pop(); 270 st.push(x[i]); 271 } 272 else 273 st.push(x[i]); 274 } 275 else if(x[i]==‘)‘) 276 { 277 while(!st.isEmpty()&&st.top()!=‘(‘) 278 { 279 y[j++]=st.top(); 280 st.pop(); 281 } 282 st.pop(); 283 } 284 } 285 while(!st.isEmpty()) 286 { 287 y[j++]=st.top(); 288 st.pop(); 289 } 290 y[j]=‘\0‘; 291 } 292 int main() 293 { 294 int x; 295 while(true){ 296 printf("------------------------------\n"); 297 printf("实验二:链式存储栈、队列的实现\n"); 298 printf("输入 1:测试链式栈;\n"); 299 printf("输入 2:测试链式队列;\n"); 300 printf("输入 3:测试顺序栈;\n"); 301 printf("输入 4:测试顺序队列;\n"); 302 printf("输入 5:后缀表达式求和;\n"); 303 printf("输入 6:中缀表达式求和;\n"); 304 305 306 printf("------------------------------\n"); 307 cin >> x; 308 switch(x) 309 { 310 case 1:{ 311 Stack st; 312 printf("输入一个整数来表示要进行的操作\n"); 313 printf("1代表入栈,2代表出栈,3代表结束\n"); 314 int a,tmp; 315 while(true){ 316 cin >> a; 317 if(a==3) 318 break; 319 switch(a) 320 { 321 case 1: 322 printf("请输入要入栈的数:"); 323 cin >>tmp; 324 st.push(tmp); 325 break; 326 case 2: 327 printf("%d\n",st.top()); 328 st.pop(); 329 } 330 } 331 break; 332 } 333 334 case 2:{ 335 Queue q; 336 printf("输入一个整数来表示要进行的操作\n"); 337 printf("1代表入队,2代表出队,3代表结束\n"); 338 int a,tmp; 339 while(true){ 340 cin >> a; 341 if(a==3) 342 break; 343 switch(a) 344 { 345 case 1: 346 printf("请输入要入队的数:"); 347 cin >>tmp; 348 q.push(tmp); 349 break; 350 case 2: 351 printf("%d\n",q.top()); 352 q.pop(); 353 } 354 } 355 break; 356 } 357 case 3:{ 358 SqStack st; 359 st_init(st); 360 printf("输入一个整数来表示要进行的操作\n"); 361 printf("1代表入栈,2代表出栈,3代表结束\n"); 362 int a,tmp; 363 while(true){ 364 cin >> a; 365 if(a==3) 366 break; 367 switch(a) 368 { 369 case 1: 370 printf("请输入要入栈的数:"); 371 cin >>tmp; 372 if(!st_push(st,tmp)){ 373 printf("栈满\n"); 374 } 375 break; 376 case 2: 377 if(st.top==-1){ 378 printf("栈空\n"); 379 break; 380 } 381 printf("%d\n",st_top(st)); 382 st_pop(st); 383 } 384 } 385 break; 386 } 387 case 4:{ 388 SqQueue q; 389 Q_init(q); 390 printf("输入一个整数来表示要进行的操作\n"); 391 printf("1代表入队,2代表出队,3代表结束\n"); 392 int a,tmp; 393 while(true){ 394 cin >> a; 395 if(a==3) 396 break; 397 switch(a) 398 { 399 case 1: 400 printf("请输入要入队的数:"); 401 cin >>tmp; 402 if(!Q_push(q,tmp)){ 403 printf("队满\n"); 404 } 405 break; 406 case 2: 407 if(q.fron==q.rear){ 408 printf("队空\n"); 409 break; 410 } 411 printf("%d\n",Q_top(q)); 412 Q_pop(q); 413 } 414 } 415 break; 416 } 417 case 5:{ 418 char x[10000]; 419 getchar(); 420 gets(x); 421 printf("%d\n",solve(x)); 422 break; 423 } 424 case 6:{ 425 char x[10000]; 426 char y[10000]; 427 428 getchar(); 429 gets(x); 430 trans(x,y); 431 puts(y); 432 printf("%d\n",solve(y)); 433 break; 434 } 435 436 default: 437 return 0; 438 } 439 } 440 441 return 0; 442 }
实验三 二叉树的设计、实现及应用
1.输入字符序列,建立二叉链表。
2.中序遍历二叉树:递归算法。
3.中序遍历二叉树:非递归算法。(最好也能实现先序,后序非递归算法)
4.求二叉树的高度 。
5.求二叉树的叶子个数。
*6.将二叉链表视为森林的孩子兄弟链表,计算森林中叶子个数。
*7.建立中序线索二叉树,并实现中序遍历。
8.借助队列实现二叉树的层次遍历。
9.在主函数中设计一个简单的菜单,分别调试上述算法。
*10.综合训练:用二叉树进行智力竞赛的判定,实现智力竞赛的自动响应。
以上是关于数据结构编程实验的主要内容,如果未能解决你的问题,请参考以下文章
20155201 李卓雯 《网络对抗技术》实验一 逆向及Bof基础