0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

算法需用编程语言很好地实现

0BFC_eet_china 来源:互联网 作者:佚名 2017-10-17 17:08 次阅读

很多人认为,算法是数学的内容,学起来特别麻烦。我们不能认为这种观点是错误的。但是我们也知道,软件是一种复合的技术,如果一个人只知道算法,但是不能用编程语言很好地实现,那么再优秀的算法也不能发挥作用。有一次,一个人问我:“你写的都是小儿科的东西,几十行代码就能搞定,能不能整一点高深的算法?”我反问他什么是他所理解的高深的算法,他答复说:“像遗传算法、蚁群算法之类的。”于是我给了他一个遗传算法求解0-1背包问题的例子,并告诉他,这也就是几十行代码的算法,怎么理解成是高深的算法?他刚开始不承认这是遗传算法,直到我给了他Denis Cormier公开在北卡罗来纳州立大学服务器上的遗传算法的源代码后,他才相信他一直认为深不可测的遗传算法的原理原来是这么简单。

还有一个人直言“用三个水桶等分8升水”之类的问题根本就称不上算法,他认为像“阿法狗”那样的人工智能才算是算法。我告诉他计算机下棋的基本理论就是博弈树,或者再加一个专家系统。但是他认为博弈树也是很高深的算法,于是我给了他一个井字棋游戏,并告诉他,这就是博弈树搜索算法,非常智能,你绝对战胜不了它(因为井字棋游戏很简单,这个算法会把所有的状态都搜索完)。我相信他一定很震惊,因为这个算法也不超过100行代码。对于上面提到的例子,我觉得主要原因在于大家对算法的理解有差异,很多人对算法的理解太片面,很多人觉得只有名字里包含“XX算法”之类的东西才是算法。而我认为算法的本质是解决问题,只要是能解决问题的代码就是算法。一个人只有有了很好的计算机知识和数学知识,才能在算法的学习上不断进步。不管算法都么简单,都要自己亲手实践,只有不断认识错误、不断发现错误,才能不断提高自己的编程能力,不断提高自己的业务水平。其实任何算法都有自己的应用环境和应用场景,没有算法可以适用于所有的场景。这一点希望大家明白。同时,我们也要清楚复杂的算法都是由普通的算法构成的,没有普通的算法就没有复杂的算法可言,所以复杂变简单,由大化小,这就是算法分治递归的基本思想。我们可以下面一个数组查找的函数说起。一句一句讲起,首先我们开始从最简单的函数构造开始:

1.intfind(intarray[],intlength,intvalue)

2.{

3.intindex=0;

4.returnindex;

5.}

这里看到,查找函数只是一个普通的函数,那么首先需要判断的就是参数的合法性:

1.staticvoidtest1()

2.{

3.intarray[10]={0};

4.assert(FALSE==find(NULL,10,10));

5.assert(FALSE==find(array,0,10));

6.}

这里可以看到,我们没有判断参数的合法性,那么原来的查找函数应该怎么修改呢?

1.intfind(intarray[],intlength,intvalue)

2.{

3.if(NULL==array||0==length)

4.returnFALSE;

5.

6.intindex=0;

7.returnindex;

8.}

看到上面的代码,说明我们的已经对入口参数进行判断了。那么下面就要开始写代码了。

1.intfind(intarray[],intlength,intvalue)

2.{

3.if(NULL==array||0==length)

4.returnFALSE;

5.

6.intindex=0;

7.for(;index< length; index++){  

8.if(value==array[index])

9.returnindex;

10.}

11.

12.returnFALSE;

13.}

上面的代码已经接近完整了,那么测试用例又该怎么编写呢?

1.staticvoidtest2()

2.{

3.intarray[10]={1,2};

4.assert(0==find(array,10,1));

5.assert(FALSE==find(array,10,10));

6.}

运行完所有的测试用例后,我们看看对原来的代码有没有什么可以优化的地方。其实,我们可以把数组转变成指针。

1.intfind(intarray[],intlength,intvalue)

2.{

3.if(NULL==array||0==length)

4.returnFALSE;

5.

6.int*start=array;

7.int*end=array+length;

8.while(start< end){  

9.if(value==*start)

10.return((int)start-(int)array)/(sizeof(int));

11.start++;

12.}

13.

14.returnFALSE;

15.}

如果上面的代码参数必须是通用的数据类型呢?

1.template

2.intfind(typearray[],intlength,typevalue)

3.{

4.if(NULL==array||0==length)

5.returnFALSE;

6.

7.type*start=array;

8.type*end=array+length;

9.while(start< end){  

10.if(value==*start)

11.return((int)start-(int)array)/(sizeof(type));

12.start++;

13.}

14.

15.returnFALSE;

16.}

此时,测试用例是不是也需要重新修改呢?

1.staticvoidtest1()

2.{

3.intarray[10]={0};

4.assert(FALSE==find(NULL,10,10));

5.assert(FALSE==find(array,0,10));

6.}

7.

8.staticvoidtest2()

9.{

10.intarray[10]={1,2};

11.assert(0==find(array,10,1));

12.assert(FALSE==find(array,10,10));

13.}

最后,我们总结一下:(1)我们的算法需要测试用例的验证(2)任何的优化都要建立在测试的基础之上(3)测试和代码的编写要同步进行(4)算法的成功运行时一步一步进行得,每一步的成功必须确立在原有的成功之上

本文转载自网络,如涉版权请联系我们删除

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 算法
    +关注

    关注

    23

    文章

    4454

    浏览量

    90747
  • 编程语言
    +关注

    关注

    9

    文章

    1878

    浏览量

    33070

原文标题:所谓的算法,有时候几十行代码就能搞定!

文章出处:【微信号:eet-china,微信公众号:电子工程专辑】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    plc编程语言与c语言的联系 c语言和PLC有什么区别

    PLC编程语言与C语言的联系 PLC(可编程逻辑控制器)是一种针对自动化控制系统的特殊计算机。PLC编程
    的头像 发表于 02-05 14:21 1018次阅读

    单片机C语言位操作的编程实现:置位和清零

    前面介绍了C语言编程的6种位操作,分别是按位与“&”、按位“或|”、按位取反“~”、异或“^”、左移“”。按位操作的定义介绍请查看这篇文章《单片机C语言编程,位操作
    的头像 发表于 11-28 09:35 2180次阅读
    单片机C<b class='flag-5'>语言</b>位操作的<b class='flag-5'>编程</b><b class='flag-5'>实现</b>:置位和清零

    脚本语言编程语言的区别

    脚本语言编程语言是计算机语言的两个主要分类。尽管两者都是用于编写计算机程序的工具,但它们在设计和运行方式上存在一些显著的区别。下面将详细探讨脚本
    的头像 发表于 11-22 14:33 1359次阅读

    什么是C语言?单片机有什么特点?为什么要用C语言编程

    随着技术的发展,电子产品越来越多,方便了我们的日常生活,大多数电子产品上都有单片机,而单片机是通过执行软件逻辑来实现功能的。而单片机编程最合适的编程语言是汇编
    的头像 发表于 11-21 10:06 707次阅读
    什么是C<b class='flag-5'>语言</b>?单片机有什么特点?为什么要用C<b class='flag-5'>语言</b><b class='flag-5'>编程</b>?

    基于Rust开发的编程语言

    Move 是一门由 Rust 语言开发的一门面向资产的编程语言,最早由 Facebook (现 Meta )投入大量的人力物力开发,用于 Libra (现 Dime )项目,处理全球性大规模支付系统的
    的头像 发表于 11-17 12:30 348次阅读

    C语言经典算法大全

    C语言经典算法,详细解析算法过程及算法思想,给读者具有启发意义,教程包含C语言大部分常用算法,仅
    发表于 10-07 08:16

    请问如何将C语言算法移植到FPGA上?

    确定算法:首先,你需要确保要移植的C语言算法是合适的。FPGA适合并行计算和高度可定制的应用。因此,你需要选择一个适合FPGA实现算法
    发表于 09-12 17:20 1027次阅读

    五种支持plc编程语言有哪些

    在PLC控制系统设计中,不同型号的PLC编程软件对以上五种编程语言的支持种类是不同的,所以不但对PLC的硬件性能了解外,也要了解PLC对编程语言
    发表于 08-31 14:54 692次阅读
    五种支持plc<b class='flag-5'>编程</b>的<b class='flag-5'>语言</b>有哪些

    如何通过C语言和梯形图实现PID控制算法

    C语言程序其实用代码将算法的加减乘除实现一下就可以了。
    的头像 发表于 07-23 16:24 683次阅读
    如何通过C<b class='flag-5'>语言</b>和梯形图<b class='flag-5'>实现</b>PID控制<b class='flag-5'>算法</b>

    PLC编程语言的特点

    PLC的编程语言与一般计算机语言相比,具有明显的特点,它既不同于高级语言,也不同与一般的汇编语言,它既要满足易于编写,又要满足易于调试的要求
    的头像 发表于 07-04 17:13 585次阅读

    西门子PLC编程语言介绍

    PLC目前有5种标准的编程语言,包括图形化编程语言和文本化编程语言
    发表于 06-29 16:00 942次阅读
    西门子PLC<b class='flag-5'>编程</b><b class='flag-5'>语言</b>介绍

    基于PASCAL的高级编程语言——SCL编程语言

    根据该标准,可对用于可编程逻辑控制器的编程语言进行标准化。SCL 编程语言实现了该标准中定义的 ST
    发表于 06-20 10:20 1062次阅读
    基于PASCAL的高级<b class='flag-5'>编程</b><b class='flag-5'>语言</b>——SCL<b class='flag-5'>编程</b><b class='flag-5'>语言</b>

    中文编程语言——青语言开源发布

    据介绍,青语言是一门面向青少年、儿童和非专业人士的中文编程语言。它完全从零开始实现了代码文本到语法树的构建,语言内核参考了 Lisp,语法上
    的头像 发表于 06-06 16:25 567次阅读
    中文<b class='flag-5'>编程</b><b class='flag-5'>语言</b>——青<b class='flag-5'>语言</b>开源发布

    TI电机控制算法里面的SVPWM原理及编程实现算法

    TI电机控制算法里面的SVPWM原理及编程实现算法对研究SVPWM,电机控制有很大的帮助
    发表于 05-15 17:11 9次下载

    上位机编程用什么语言 上位机编程软件哪个好

    上位机编程可以使用多种编程语言实现,具体取决于应用场景、控制任务以及硬件设备的特性等因素。以下是一些通常用于上位机编程
    的头像 发表于 05-08 15:35 1.2w次阅读