大榕树——让我们共成长!
大榕树 myDrs.org
您的位置:大榕树 \ 编程       |  Logo语言   |  Pascal语言   |  信息学奥赛   |  高考保送    |  HTML版本
|  Pascal语言>>算法与技巧>>程序优化技巧         本站全文搜索: 友情提示:

程序优化技巧
http://www.mydrs.org  7/7/2001  大榕树


1 时间优化[/b]
很大的课题啊!我在这里抛砖引玉了,呵呵。
我只准备讲时间优化和空间优化,其他的就...

1.时间优化
本来有三个方面:
a.数据结构优化
b.算法优化
c.编码优化
d.空间换时间

因为a我将在数据结构的选择这一部分较详细的描述,b我将在剪枝这一部分作一个讨论,
这里我只是讲第三种,针对的是PASCAL语言

1.快速操作。
有:inc,dec,include,exclude。大家可以看看TP的HELP

2.赋值的问题
假设:
s:shortint;
i:integer;
l:longint;

以下语句执行10^8次。
l:=s; 3.46s
i:=s; 2.80s
s:=s; 2.42s
l:=i; 3.19s
i:=i; 2.42s
l:=l; 2.91s

l:=s比l:=l还要慢...

记住一句话:不要做没用的事,不要做重复的事。看起来简单,但以后你们会体会到它的作用。

介绍一篇英文文章(PDF):Optimization

[b]2 空间优化

这里我们简单的讨论一下空间优化。
1)充分的利用空间
2)只储存必要的信息
3)时间换空间

[例子1]
时间换空间的例子:
NOI98第一题《个人所得税》,测试数据很大,一次读完根本不可能,就需要
多次读文件,一次处理5000个人(或1个月的数据)

[例子2]
数据结构的例子:
对于二元坐标,如果0<=x<=10, 0<=y<=10,就储存成一个数z,
x=z div 11; y=z div 11;
这样:一个坐标数据的大小就减少了一半。

[例子3]
指针占4个字节,所以链表的开销实际上很大,如果把指针改成索引就...
NOI2000的《单词查找树》就可以这么做。


作 者:SRbGa
来 源:OIBH
共有2942位读者阅读过此文

  • 上篇文章程序测试技巧
  • 下篇文章基本程序结构和几个概念

  • 发送邮件
    保存页面 打印文章 HTML版本 发表评论

    □- 近期热门文章 □- 相关文章
    1. NOIP2006竞赛大纲 [8306]
    2. 七类高中生具有保送资格 [5910]
    3. NOI2006获奖选手名单 [4955]
    4. 关于举办NOIP2006模拟赛的通告 [4106]
    5. Turbo Pascal各语句运行速... [3594]
    6. Turbo王者归来新Delphi免费... [3181]
    7. IOI2006我国4名选手全部获得金... [2945]
    8. 关于APIO2007与IOI2007... [2763]
    9. noip倒计时 by 枯叶蝴蝶 [2683]
    10. 朱泽园:思想上的金牌更重要 [2168]
    程序优化技巧
     

    关于本站 | 合作伙伴 | 联系方式
    大榕树 版权所有 ©1999-2006 www.myDrs.org 闽ICP备05000721号