- 1、本文档共21页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
acm数据结构总结
Pku acm 3253 Fence Repair 数据结构题目总结(一) ----哈夫曼数?这是一个哈夫曼数的简单例子,算法很简单,但提交了很多次才ac,但每一个版本都有很多收获。
1.利用Java的集合类以及排序的方法,简单的实现其中的排序,将所有的num添加到集合中,然后排序,提取第1.2个元素,然后相加,删除这两个元素,添加这两个元素的和,然
后排序,直到集合的元素个数给1.另外,在该程序中使用了jdk1.5支持的输入,大大简化了输入:Scanner cin = new Scanner(System.in);int count = cin.nextInt();核心的代码如下:Collections.sort(array);int sum=0,a,b;while(array.size()!=1){?a = array.get(0);?b = array.get(1);?array.add(a+b);?array.remove(0);?array.remove(1);//注意这里不是1,因为删除一个后集合原来的第1个元素变为了第0个元素?sum += a+b;?Collections.sort(array);}System.out.println(sum);
但是这个实现虽然简单,但超时,运行需要2s多,而题目要求1s
2.为了避免排序,采用空间换时间的策略.想法是这样的:建立一个数组length[],该数组的第i个元素表示:集合中有该元素的个数,然后从小到大选出最小的a和b,将length
[a]--,length[b]--,length[a+b]++,直到数组中没有非零元素.核心代码如下:??? scanf(%d,n);??? for(i=1;i=n;i++)??? {??????? scanf(%d,temp);??????? length[temp]++;??? }??? for(i=1;in;i++)??? {??????? while(!length[j])??????????? j++;??????? a=j;??????? length[j]--;??????? while(!length[j])??????????? j++;??????? b=j;??????? length[j]--;??????? length[a+b]++;??????? sum += a+b;??? }结果运行中错误,原因是数组开的不够大,题目要求有20000个数字,每个数字最大为50000,如果要满足题目要求length长度为50000*20000,无法开如此大的数组.
3.由于数组中有大量的插入和删除的操作,准备采用链表存储,输入的结果是一个由小到大排列的链表,然后删除前两个数字,插入两个数字的和,按顺序插入到链表中.核心代码如下:???但是依然超时.
for(i=1;i=n;i++)??? {?//动态分配待插入节点存储空间??????? struct LNode* p_insert=(struct LNode*)malloc(sizeof(struct LNode));??????? scanf(%d,p_insert-data);???
??????? p_head=head;?//插入前链表为空???????? if(head-next==NULL)??????? {??????????? p_head-next=p_insert;p_insert-next=NULL;??????? }??????? else??????? {???? //查找该插入的地方???????????? while(p_head-datap_insert-datap_head-next!=NULL)??????????? {??????????????? p_temp=p_head;??????????????? p_head=p_head-next;??????????? }???? //不是插入到链表结尾???????????? if(p_head-data=p_insert-data)??????????? {??????????????? p_temp-next=p_insert;??????????????? p_insert-next=p_head;??????????? }???? //插入到链表结尾???????????? else??????????? {??????????????? p_head-next=p_insert;??????????????? p_insert-next
您可能关注的文档
最近下载
- 4 JieLink+智能终端操作平台系统调试说明书V1.0.doc
- 2022数学新课标背景下:基于项目式学习的创新教学实例.docx VIP
- 有机合成第六章.ppt VIP
- 抖音来客本地服务行业实体门店运营培训教程(三)抖音实体门店商家经营思路.pptx
- (正式版)D-L∕T 5862-2023 电化学储能电站施工图设计内容深度规定.docx VIP
- 苏教版三年级数学下册《全程测评卷》.doc
- 2024年~2022年浙江省国企招聘历年面试题目及答案解析50套.docx
- 高中物理游标卡尺、千分尺、螺旋测微器读数习题集.doc
- 中考英语作文万能模板及万能句型汇总.docx VIP
- 五个认同爱国主义教育课件.pptx
文档评论(0)