以前看过一篇文章“优化C代码常用的几招”,作者提到的第一招就是“以空间换时间”,还举了一个例子,由于比较经典,引用一下:
计算机程序中最大的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考虑程序的效率问题,我们就有了解决问题的第1招--以空间换时间。比如说字符串的赋值:
方法A:通常的办法
#define LEN 32
char string1 [LEN];
memset (string1,0,LEN);
strcpy (string1,"This is a example!!");
方法B:
const char string2[LEN] ="This is a example!";
char * cp;
cp = string2;
使用的时候可以直接用指针来操作。
从上面的例子可以看出,A和B的效率是不能比的。在同样的存储空间下,B直接使用指针就可以操作了,而A需要调用两个字符函数才能完成。B的缺点在于灵活性没有A好。在需要频繁更改一个字符串内容的时候,A具有更好的灵活性;如果采用方法B,则需要预存许多字符串,虽然占用了大量的内存,但是获得了程序执行的高效率。

笔者在编程练习过程中也遇到了不少可以用空间换时间的算法,把它们收集起来,以便初学者学习查阅。
1.桶式排序算法
最经典的应用是“桶式排序算法”。数组的排序算法很多,其中快速排序是在实践中最快的已知排序算法,它的平均运行时间是O(NlogN),堆排序算法在最坏的情况下,其时间复杂度也能达到O(nlogn)。相对于快速排序来说,这是它最大的优点,但是它需要一个记录大小供交换用的辅助存储空间-----其实这也是用空间换时间的表现。但是,当数组的元素是一些较小的整型数据(小于1000000)时,用“桶式排序算法”可以使时间复杂度降到O(N),可以很快地对年龄,成绩等整型数据进行排序。此外还可以使用桶式排序的方法求素数表。
“桶式排序算法”的代码也很简单,只要建立一个长度为max的字符数组就可以了,代码如下:
/*
函数功能:使用筒式排序法对数组进行排序,适用于元素值为较小整数
输入变量: int a[], 数组a
           int len,数组a的长度    
输出变量:无
返回值: 无
*/

void Sort(int a[], int len)
{
    int max = GetMax(a, len);
    char *p = new char[sizeof(char) * max + 1];

for (int i=0; i<=max; ++i)
        p[i] = 0;

for (int i=0; i<len; ++i)
        ++p[a[i]];
        
    for (int i=0,j=0; i<=max; ++i)
    {
        while (p[i] > 0)
        {
            a[j++] = i;
            --p[i];
        }
    }
    
    delete []p;
}

/*
函数功能:返回数组的最大值
输入变量: int a[], 数组a
           int len,数组a的长度    
输出变量:无
返回值: 数组的最大值
*/

int GetMax(int a[], int len)
{
    int max = a[0];
    
    for (int i=1; i<len; i++)
    {
        if (max < a[i])
            max = a[i];
    }
    
    return max;
}

以空间换时间经典算法相关推荐

  1. 以空间换时间——动态规划算法及其应用:矩阵链相乘

    动态规划算法是5大算法基础中最重要的一个,它专门用来解决平面世界下的应用,即会多次使用二维数组. 当然动态规划算法是空间换时间的算法,也就是说:我们可以利用空间资源来使某算法问题的时间复杂度降到最低. ...

  2. 空间换时间,查表法的经典例子

    前言 上一篇分享了:C语言精华知识:表驱动法编程实践 这一篇再分享一个查表法经典的例子. 我们怎么衡量一个函数/代码块/算法的优劣呢?这需要从多个角度看待.本篇笔记我们先不考虑代码可读性.规范性.可移 ...

  3. 空间换时间--编程小绝招解决电话区号识别算法问题

    空间换时间问题通常都是一个不大的问题里的一个不小的解决方案.首先要理解代码中函数的一个大致的代价,在输入比较固定,计算输出又比较费劲的时候,常常就是空间换时间发挥作用的时候了.通过几个简单的例子您就会 ...

  4. JS哈希表算法——空间换时间

    题目来源力扣: 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,数组中同一个元素 ...

  5. FPGA之道(62)时空变换之空间换时间

    文章目录 前言 时空变换之空间换时间 缓存提速使用 模块复制 同频模块复制 缓存降频复制 缓存降频使用 逻辑拆分 流水线 流水线的由来 如何在组合逻辑中使用流水线 如何在时序逻辑中使用流水线 顺序系统 ...

  6. 什么叫用空间换时间,用时间换空间

    什么叫做用空间换时间 用空间换时间是指为了提高程序或算法的效率,将计算机程序中的时间复杂度转化为空间复杂度,即通过使用更多的空间来减少程序运行所需的时间.这种技术在某些情况下可以大幅缩短程序的执行时间 ...

  7. leetcode-383-Ransom Note(以空间换时间)

    题目描述: Given an arbitrary ransom note string and another string containing letters from all the magaz ...

  8. 前端遍历导致查询数据时间过长_OLAP 服务器,空间换时间可行吗?

    [摘要] 全量预汇总真的是提高 OLAP 性能的可行方案吗?点击了解OLAP 服务器,空间换时间可行吗? 多维分析提供拖拽.旋转.切片.钻取等等人机交互操作,必须有秒级的响应速度.而这些操作对应的明细 ...

  9. [hashmap|空间换时间] leetcode 1 两数之和

    [hashmap|空间换时间] leetcode 1 两数之和 1.题目 题目链接 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下 ...

  10. ie浏览器查看vue中js_浅析 Vue.js 中那些空间换时间的操作

    Hello,各位小伙伴,接下来的一段时间里,我会把我的课程<Vue.js 3.0 核心源码解析>中问题的答案陆续在我的公众号发布,由于课程的问题大多数都是开放性的问题,所以我的答案也不一定 ...

最新文章

  1. CentOS7下启动Nginx出现Failed to start nginx.service:unit not found
  2. Wiew 像写 Android UI 一样写小游戏布局
  3. xlrd,xlwt模塊
  4. vim打开所有折叠的方法及其他所有折叠的命令
  5. 2011年 CIO简历该怎么写?
  6. 2014年JAVA省赛B组---第四题---大衍数列
  7. Swift-EasingAnimation
  8. java中 银行存款取款_java银行存款取款
  9. 在高考作弊这事上,古今监考老师操碎了心!
  10. 网易云音乐linux版_全线下架:网易云音乐难解的困境
  11. AVR单片机项目教程 基于C语言,AVR单片机项目教程:基于C语言(第2版)
  12. minitab怎么算西格玛水平_计算西格玛水平.ppt
  13. 1ke android逆向助手_android逆向助手
  14. xlwings使用笔记
  15. 物联网概念火热,靠技术如何落地?
  16. 两组字符串去重/两个列表去重
  17. 使用Inno Setup软件直接给安装程序和卸载程序加数字签名
  18. 信息学奥赛一本通 1244:和为给定数 通过
  19. 央行姚前: 数字加密代币ICO及其监管研究
  20. 小程序 小程序跳转公众号页面

热门文章

  1. 微信小程序运营之如何获取流量
  2. Echart饼状图百分比显示
  3. KiCad 部分插件安装
  4. 算法设计技巧与分析 答案整理
  5. 英语作文 计算机新技术对生活的影响,科技的影响高中英语作文3篇
  6. 发票专用驱动sjz_税务局紧急提醒!10月31日前,不能领票,不能勾选!11月1日后,发票开具将大不同!...
  7. Unity Compute Shader入门(大量对象随机赋值颜色实验)
  8. git官网下载慢的问题解决方法
  9. UVALive 7461 - Separating Pebbles
  10. MiniUtilityFramework 九 CText和TEXT