09级ds(超市密码存储箱系统的设计与实现等)实验代码

上传人:细水****9 文档编号:57210302 上传时间:2022-02-23 格式:DOC 页数:17 大小:38KB
返回 下载 相关 举报
09级ds(超市密码存储箱系统的设计与实现等)实验代码_第1页
第1页 / 共17页
09级ds(超市密码存储箱系统的设计与实现等)实验代码_第2页
第2页 / 共17页
09级ds(超市密码存储箱系统的设计与实现等)实验代码_第3页
第3页 / 共17页
点击查看更多>>
资源描述
超市密码存储箱系统的设计与实现设计方案(1) 存储结构类型定义/*密码箱的存储结构类型定义*/Typedef struct node Int num;/*箱子的号码*/ Long int password;/*箱子的密码(满箱有,空箱无)*/ Struct node *next;/*指向下个结点的指针*/node ,*linklist;(2)主要功能函数设计建立链表:最初所有的箱子为空,按照序号依次插入链表L1中,链表L2为空。LinkList Createlist1 /*建立空箱子链表L1,初始时共12个结点*/ Int I ; Linklist head,p,q; Head=(node * )malloc(sizeof(node); /*创建头结点*/ Head next = NULL; P =head; For(i = 1;i=12;i+ ) /*依次建立12个结点,并插入链表中*/ q=(node *)malloc(sizeof(node); qnum = i; /*每个结点的编号*/ qnext = pnext; /*将结点插入链表*/ pnext = q; p = q; Return head; /*返回链表的头结点*/Linklist Createlist2 /*建立满箱子链表L2,初始时为空*/Linklist head;Head =(node *)malloc(sizeof(node); /*创建头结点*/Head next =NULL;Return head; /*返回链表的头结点*/寻找空箱子:判断链表L1是否为空,若不空,则取出第一个结点(即将其从链表L1中删除),然后随机产生一个6位密码,并将此密码依次与链表L2中所有结点的密码相比较,若发现有重复,则重新生成一个密码,直到没有重复为止。将密码写入此箱子结点的password域,然后将此节点插入L2链表。Long int mima /*密码产生函数*/Long n,m;Randomize;M = random(9)+1;N=(m*100000 +random(1000000)1000000; /*产生6位数的密码*/Return(n);Int compare(linklist head,long int x) /*比较是否有重复的密码,若有返回0,无则返回1*/Node *q;For(q =head;q!=NULL;q=qnext) /*在链表中搜索*/ If(q password = x)Return 0;Return 1;Linklist Delnode(Linklist head) /*在链表中删除第一个结点*/ Node *p;P=headnext;Head next =pnext;Return p;Void insertnode(linklist head,node*p)/在链表头结点后插入一个结点Pnext=head next;Head next =p;取包:输入密码,在链表L2中依次查找是否有与顾客输入密码相符的结点,找到后取出该结点,将其从链表L2中删除,然后将其插入链表L1中。Linklist pcompare(Linklist head,long int x)/开箱前查看是否有此箱,若有将它从L2中删除,返回指向它的指针 Node *p,*q; For(p =head,q =headnext; q!=NULL;q=qnext)If (q password = x) P next=qnext;Return q; /*返回指向此箱的结点*/else p=q;Return NULL; /*若无此箱则返回空指针*/(3)实现程序#include ”graphics.h”#include ”stdlib.h”#include ”stdio.h”#include ”string.h”# include ”time.h”Typedef struct node Int num;Long int password;Struct node *next;node,*linklist; /*在屏幕上画出箱子,共12个,3行四列,箱体为蓝色*/Void DrawBox( ) int x,y,i=1; Char st3; Setcolor(3);For(x=300;x=500;x+=50) Line(x,50,x,200);For(y=50;y=200;y+=50)Line(300,y,500,y);Setfillstyle(SOLID_FILL,1);For(y=50;y=150;y+=50)For(x=300;x=450;x+=50)itoa(i,st,10);floodfill(x+30,y+30,3);outtextxy(x+20,y+25,st); /在每个箱子上标上箱子的编号:1-12i=atoi (st);i+; Int dm(int x) /辅助计算机填充坐标的参数Int m;M=x%4;If(m=0)m=4;Return m;Int dn(int x) /辅助计算机填充坐标的参数int n;If(x=4) n=1;Elseif(x8) n=2;Else if(xnext=NULL) Printf(“满箱!n”);Elsep=DelNode(head1); /将其从链表L1中删除 P-password=MiMa( ); /生成密码 While(!compare(head2,p-password)/若密码重复,则重新生成 P-password=MiMa( ); Printf(“% 1dn”, p-password); InsertNode(head2,p); /将其从插入链表L2中 M=dm(p-num);N=dn(p-num);Fillcolor(300+m*50-10,50+n*50-10,4); /将此箱子变为红色If(k=2)printf(“请输入密码:”);Scanf(“% 1d”,&t);If(head2-next!=NULL)p=pcompare(head2,t);Ip(p=NULL) continue;InsertNode(head1,p);M=dm(p-num);N=dn(p-num);Fillcolor(300+m*50-10,50+n*50-10,1); /将此箱子变为蓝色哈夫曼编码/译码系统案例描述。#difine N 50 /叶子结点数,即在信息中最多可出现30种字符Typedef structchar data; / int weigth;int Lchild,rchild,parent;HTNode;Void creatHufmTree(HTNode ht,int n)int I,k,m1,m2,l,r; For(i=1;i=2*n;i+) Hti.lchild= Hti.rchild= Hti.parent=0; For(i=n+1;i=2*n-1;i+) m1=m2=10000; L=r=0 For(k=1;k=i-1;k+) If(htk.parent=0 & htk.weigthm1) m2= m1;r=1 m1= htk.weigth; l=k; else (htk.parent=0 & htk.weigthm2) m2= htk.weigth; r=k; htl.parent=i;htr.parent=i;hti.weigth= htl.weigth+ htr.weigth;hti.lchild=l;hti.rchild=r;(2)哈夫曼编码的生成哈夫曼编码的存储结构类型定义为:Typedef structChar bitsN;Int start;Hcode;Void HufmCode(HTNode ht;Hcode hcd,int n)Int i,f,c,k;Hcode cd;For(i=1;i=n;i+)cd.start=n+1;c=i;f=hti.parent;while(f!=0) If(htf.lchild=c) Cd.bits-cd.start=0;Else cd.bits-cd.start=1;c=f;f=htf.parent;Hcdi=cd;Printf(“输出哈夫曼编码:n”);For(i=1;i=n;i+)Printf(“% c:”,hti.data);For(k=hcdi.start;k=n;k+)Printf(“% c:”,hcdi.bitsk);Printf(“n”);(3)对编码信息的翻译Void tscode(char *bit,htnode ht,int n) /*哈夫曼树的译码*/Int I;I=2*n-1; /*将树根结点的下标赋i,从根结点出发向下搜索*/While(*bit!=0) /*若编码没有结束*/If(*bit=0) I=hti.lchild; /*走向左孩子结点*/Else I=hti.rchild; /*走向右孩子结点*/If(hti. lchild=0) /*判断是否已经走到叶子结点*/ Putchar(hti.data); /*输出此编码对应的字符*/ I=2*n-1 /*重新回到根节点,准备下一次搜集*/Bit+; /*取编码中的下一个代码*/(4)程序实现#include”stdio.h”#include”string.h”#include”conio.h”#include”stdlib.h”#define N30 /*最大叶子结点数*/Typedef struct Char data; /*编码对应的字符*/ Int weight; /*结点的权值*/ Int lchild,rchild,parent; /*左右孩子及双亲的下标*/htnode;Typedef struct Char bitsn; /*存放哈夫曼编码的字符数组*/ Int start; /*编码的起始位置*/hcode ;Int stat(char *st,int cnt.char str) /*统计字符信息中出现的字符种类数和各字符出现的次数*/ Char*p; Int I,j,num27; For(i=1;i=26;i+) Numi=0; For(p=st;*p!=0;p+) *p=tolower(*p); /*若字符信息中有大写字母,则将其转换成小写字母*/ If(*p=a&*p=z) k=*p-96; numk+;j=0;for(i=1;i=26;i+) if(numi!=0) J+; Strj=i+96; Cntj=numi;Return j;Main Int I,j,k,n,t,x,cnt27; Char st50,sr27,bm200; Htnode hcd2*n-1; /*用于存放树中所有结点*/ Hcode hcdn; /*用于存放字符的哈夫曼编码*/ While(1)Printf(”1-输入待传送的字符信息 2-编码 3-发送 4-接收并译码 0-退出n”);Scanf(”%d”,&x);Switch(x)Case 1:printf(”请输入要发送的字符串信息:”); Scanf(”%s”,st); Break;Case 2:n=stat(st,cnt,sr); Creathufmtree(ht,n,sr,cnt); Hufmcode(ht,hcd,n); Break;Case 3:t=0;For(j=0,stj!=0;j+)For(i=1;i=n;i+) If(hti.data=stj)For(k=hcdi.start;k=n;k+)Bmt=hcdi.bitsk;T+;Break;Bmt=0;Printf(”发送完毕!n”);Break;Case4:paintf(”接受到的编码信息为:”); Puts(bm); Printf(”译码后的结果为:”); Tscode(bm,ht,n); Printf(”n”); Break;Case0:exit(0);
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 其他分类 > 其它学术


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!