欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    数据结构算法源代码.pdf

    • 资源ID:86051423       资源大小:238.65KB        全文页数:17页
    • 资源格式: PDF        下载积分:19.9金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要19.9金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    数据结构算法源代码.pdf

    #include#include#include#include#include /*声明两种链表结构-start*/struct node_a /*链表 1-作用:用来统计文件中字符的个数和种类(通过 count)*/char data;int count;struct node_a*next;typedef struct node_a node,*list;list head=NULL;struct nodeb /*链表 2-作用:用来建立用相应的编码代替字符的新文件*/char data;struct nodeb*next;typedef struct nodeb node_b,*list_b;/*jiang bianma xieru wenjian*/list_b head_b=NULL;/*声明两种链表结构-end*/*哈夫曼算法种相关的 3 种结构的声明-start*/struct forest float weight;int root;struct alphabet char symbol;float probability;int leaf;char*bianma;struct tree int lchild;int rchild;int parent;typedef struct tree*tree_ptr,tree_node;typedef struct forest*forest_ptr,forest_node;typedef struct alphabet*alphabet_ptr,alphabet_node;tree_ptr tree1;forest_ptr forest1;alphabet_ptr alphabet1;int lasttree,lastnode;int least,second;/*哈夫曼算法种相关的 3 种结构的声明-end*/*stack difination start*/struct stacknode char*bian_ma;struct stacknode*next;typedef struct stacknode stack_node;typedef stack_node*link;link top=NULL;void push(char*item)link p;if(top!=NULL)p=(link)malloc(sizeof(stack_node);if(p=NULL)printf(Memory allocation error!);return;p-bian_ma=item;p-next=top;top=p;else top=(link)malloc(sizeof(stack_node);if(!top)printf(Memory allocation error!);return;top-bian_ma=item;top-next=NULL;void pop(void)link p;p=top;top=top-next;free(p);void makenull(void)while(top!=NULL)pop();int empty()if(top=NULL)return 1;else return 0;char*tops(void)return(top-bian_ma);void display_stack(link s)/*显示栈重的内容*/link ptr;ptr=s;while(ptr!=NULL)printf(%s,ptr-bian_ma);ptr=ptr-next;/*stack_difination is end*/void display(list h)/*显示链表 1*/list ptr;int i=1;ptr=h-next;while(ptr!=NULL)printf(%d,%c,%dn,i,ptr-data,ptr-count);i+;ptr=ptr-next;void display_b(list_b h)/*显示链表 2*/list_b ptr;int i=1;ptr=h-next;while(ptr!=NULL)printf(%d,%cn,i,ptr-data);i+;ptr=ptr-next;void insert(char item)/*用于插入元素以建立链表 1*/list temp,ptr;int flag;ptr=head-next;if(ptr=NULL)head-next=(list)malloc(sizeof(node);head-next-data=item;head-next-count=1;head-next-next=NULL;else while(ptr!=NULL)if(ptr-data=item)ptr-count=ptr-count+1;flag=1;ptr=ptr-next;ptr=head;if(flag=1)return;else temp=ptr-next;ptr-next=(list)malloc(sizeof(node);ptr-next-data=item;ptr-next-count=1;ptr-next-next=temp;void insert_b(char item)/*插入元素以建立链表 2*/list_b ptr_b,temp_b;ptr_b=head_b;if(ptr_b-next=NULL)head_b-next=(list_b)malloc(sizeof(node_b);head_b-next-data=item;head_b-next-next=NULL;else while(ptr_b-next!=NULL)ptr_b=ptr_b-next;ptr_b-next=(list_b)malloc(sizeof(node_b);ptr_b-next-data=item;ptr_b-next-next=NULL;void search(void)/*搜索文件并将文件中的数据分别存入作用不同的链表中*/FILE*fp;list ptr;char ch;if(fp=fopen(test.txt,r)=NULL)printf(Reading error!n);while(!feof(fp)ch=getc(fp);if(ferror(fp)printf(error!n);break;if(ch=EOF)break;insert(ch);/*插入元素进链表 1*/insert_b(ch);/*插入元素进链表 2*/printf(n);fclose(fp);void display_struct(int n)/*显示哈夫曼算法中的 3 个结构树组*/int i=0;printf(nn=nn);printf(FOREST_STRUCT_ARRY:nnn);for(i=0;i=n;i+)printf(%f,%dn,forest1i.weight,forest1i.root);getch();printf(nnALPHABET_STRUCT_ARRY:nnn);for(i=0;i=n;i+)printf(%f,%d,%cn,alphabet1i.probability,alphabet1i.leaf,alphabet1i.symbol);getch();printf(nnTREE_STRUCT_ARRY:nnn);for(i=0;inext;while(ptr!=NULL)count=ptr-count+count;n+;ptr=ptr-next;ptr=head-next;forest1=(forest_ptr)malloc(sizeof(forest_node)*n+sizeof(forest_node);alphabet1=(alphabet_ptr)malloc(sizeof(alphabet_node)*n+sizeof(alphabet_node);tree1=(tree_ptr)malloc(sizeof(tree_node)*n*2-sizeof(tree_node);forest10.weight=alphabet10.probability=0.0;forest10.root=alphabet10.leaf=0;alphabet10.symbol=0;while(ptr!=NULL)forest1i.weight=alphabet1i.probability=ptr-count/count;forest1i.root=alphabet1i.leaf=i;alphabet1i.symbol=ptr-data;i+;ptr=ptr-next;for(i=0;i=2*n-1;i+)tree1i.lchild=0;tree1i.rchild=0;tree1i.parent=0;return n;void creat(void)/*创建正文文件 test.txt*/FILE*fp,*out;char ch;if(fp=fopen(test.txt,r+)=NULL)printf(Creat error!n);printf(Input the data:n);ch=getch();putch(ch);while(ch!=#)putc(ch,fp);ch=getch();putch(ch);fclose(fp);void creat_bianma(int number)/*根据哈夫曼算法建立文件中各种字符对应的编码*/int i,j,n;int p;char*bm=malloc(sizeof(char)*number);for(n=1;nnext;if(fp=fopen(bianma.txt,w)=NULL)printf(Write in a new file error!);else while(ptr!=NULL)for(i=1;idata=alphabet1i.symbol)strcpy(ch,alphabet1i.bianma);fputs(ch,fp);ptr=ptr-next;fclose(fp);void main(void)int i,num;char ch;void huffman(void);void lightones();head=(list)malloc(sizeof(node);head-next=NULL;head-data=0;head-count=0;head_b=(list_b)malloc(sizeof(node_b);head_b-data=0;head_b-next=NULL;do system(cls);creat();search();printf(nlianbiao1:n);display(head);/*显示链表 1*/getch();printf(nlianbiao2:n);display_b(head_b);getch();num=init_struct();printf(n);printf(The 3 init_struct of huffman?n);display_struct(num);/*显示初始化的哈夫曼书的相关 3 个结构数组*/lastnode=num;lasttree=num;huffman();printf(Now the 3 struct through huffman shuanfan);display_struct(num);/*显示哈夫曼树中相关的 3 种结构(经过哈夫曼算法处理)*/printf(nThe bian_ma is:n);creat_bianma(num);write_new_file(num);printf(nDo you want to re_try(y/n)?);ch=getchar();while(ch=y);/*哈夫曼算法-defination_start*/void lightones(void)int i;if(forest11.weight=forest12.weight)least=1;second=2;else least=2;second=1;for(i=3;i=lasttree;i+)if(forest1i.weightforest1least.weight)second=least;least=i;else if(forest1i.weight1)lightones();i=least;j=second;newroot=creat_tree(i,j);forest1i.weight=forest1i.weight+forest1j.weight;forest1i.root=newroot;forest1j=forest1lasttree;lasttree=lasttree-1;#include#include#include#define n 6#define m 2*n-1 typedef struct float weight;int lchild,rchild,parent;codenode;typedef codenode huffmantreem;typedef struct char ch;char bitsn+1;code;typedef code huffmancoden;void inithf(huffmantree T)/哈夫曼树的初始化 int i;for(i=0;im;i+)Ti.weight=0;Ti.parent=-1;Ti.lchild=-1;Ti.rchild=-1;void inputhf(huffmantree T)/输入哈夫曼树的树据 int i;float k;for(i=0;in;i+)scanf(%f,&k);Ti.weight=k;void selectmin(huffmantree T,int k,int*p1,int*p2)int i;float small1=10000,small2=10000;for(i=0;i=k;i+)if(Ti.parent=-1)if(Ti.weightsmall1)small2=small1;small1=Ti.weight;*p2=*p1;*p1=i;else if(Ti.weightsmall2)small2=Ti.weight;*p2=i;void creathftree(huffmantree T)/建哈夫曼树 int i,p1,p2;inithf(T);inputhf(T);for(i=n;im;i+)selectmin(T,i-1,&p1,&p2);Tp1.parent=Tp2.parent=i;Ti.lchild=p1;Ti.rchild=p2;Ti.weight=Tp1.weight+Tp2.weight;void creathfcode(huffmantree T,huffmancode H)/哈夫曼编码表 int i,c,p,start;char cdn+1;cdn=0;for(i=0;i=0)cd-start=(Tp.lchild=c)?0:1;c=p;strcpy(Hi.bits,&cdstart);void zip(huffmancode H,char*ch,char*s)/编码 int j=0;char*pn;unsigned int i;for(i=0;istrlen(ch);i+)while(chi!=Hj.ch)j+;pi=Hj.bits;strcpy(s,p0);for(i=1;in;i+)strcat(s,pi);puts(s);void uzip(huffmancode H,char*s,huffmantree T)/解码 int j=0,p;unsigned int i;char chn+1;while(istrlen(s)p=m-1;while(Tp.lchild!=-1)if(s i =0)p=Tp.lchild;i+;else p=Tp.rchild;i+;chj=Hp.ch;j+;chj=0;puts(ch);main()char ch=abcdef,s36;huffmantree T;huffmancode H;creathftree(T);getchar();creathfcode(T,H);zip(H,ch,s);uzip(H,s,T);/*这是我在这里帮落尘改写的程序,今天又吧它改写成了 c 的 借鉴一下吧*/#include#include typedef struct node int data;struct node*lchild,*rchild;*treetp,tree;treetp create(treetp t,int c);void print1(treetp);void print2(treetp);void print3(treetp);int number=0;void main()treetp t=0,r;r=create(t,0);printf(前序排列:);print1 (r);printf(n 中序排列:);print2(r);printf(n 后序排列:);print3(r);treetp create(treetp t,int c)treetp p,di;do scanf(%d,&c);if(t=0)t=(treetp)malloc(sizeof(tree);t-lchild=t-rchild=0;t-data=c;else p=t;while(p!=0)di=p;if(cdata)p=p-lchild;else p=p-rchild;if(cdata)treetp NEWdi=(treetp)malloc(sizeof(tree);NEWdi-lchild=NEWdi-rchild=0;NEWdi-data=c;di-lchild=NEWdi;else treetp NEWdi=(treetp)malloc(sizeof(tree);NEWdi-lchild=NEWdi-rchild=0;NEWdi-data=c;di-rchild=NEWdi;+number;while(c!=0);printf(叶子的数量:%d,number);return t;void print1(treetp t)if(t!=0)printf(%d,t-data);print1(t-lchild);print1(t-rchild);void print2(treetp t)if(t!=0)print2(t-lchild);printf(%d,t-data);print2(t-rchild);void print3(treetp t)if(t!=0)print3(t-lchild);print3(t-rchild);printf(%d,t-data);#include#include#define MAX 20#define ELEMTP int#define v(*p)struct sequnce ELEMTP elemMAX;int len;main()struct sequnce*pz;int i,y,cord;void outlin(struct sequnce s);void create(struct sequnce*p);void insert(struct sequnce*p,int i,int x);void deletes(struct sequnce*p,int i);do printf(n 主菜单 n);printf(1 建立线性表 n);printf(2 插入一个元素 n);printf(3 删除一个元素 n);printf(4 结束程序运行 n);printf(-n);printf(请输入您的选择(1,2,3,4);scanf(%d,&cord);switch(cord)case 1:pz=(struct sequnce*)malloc(sizeof(struct sequnce);create(pz);outlin(*pz);break;case 2:printf(请输入插入的位置 i:);scanf(%d,&i);printf(请输入插入的数据 y:);scanf(%d,&y);insert(pz,i,y);outlin(*pz);break;case 3:scanf(%d,&i);deletes(pz,i);outlin(*pz);break;case 4:exit(0);while(cord=4);void outlin(struct sequnce s)int i;for(i=1;i=s.len;i+)printf(%2d%6dn,i,s.elemi);void deletes(struct sequnce*p,int i)int j;if(iv.len)printf(i,位置不存在);else for(j=i;jv.len;j+)v.elemj=v.elemj+1;v.len-;void insert(struct sequnce*p,int i,int x)int j;if(iv.len+1)printf(i 位置不存在。);else for(j=v.len;j=i;j-)v.elemj+1=v.elemj;v.elemi=x;v.len+;void create(struct sequnce*p)int i;printf(n=);scanf(%d,&(v.len);for(i=1;i=v.len;i+)printf(data=);scanf(%d,&(v.elemi);

    注意事项

    本文(数据结构算法源代码.pdf)为本站会员(g****s)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

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

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开