我应该知道哪些计算机科学概念 (computer information concepts)

您认为计算机科学中的哪些概念使您成为更好的程序员?

您认为计算机科学中的哪些概念使您成为更好的程序员?

我的学位是机械工程,所以最终成为一名程序员,我有点缺乏基础知识。我最近学到了一些标准的 CS 概念,这些概念让我对我正在做的事情有了更深入的了解,特别是:

语言功能

指针和 amp;递归(感谢乔尔!)

数据结构

链接列表

哈希表

Algorithms

气泡排序

显然,该列表是目前有点短,所以我希望的建议:

我应该理解什么概念,

正确理解它们的任何好的资源(因为有时可能有点密集和学术)。

63

看看 Steve Yegge(以前是亚马逊,现在是谷歌)的这篇博客文章:

The Five Essential Phone Screen Questions

它详细介绍了开发人员应该了解的五个最重要的概念:

基本编程(包括递归,文件 I / O,格式化输出,循环等)

面向对象的设计(包括设计模式等),你应该能够产生明智的面向对象的设计以及理解的概念。

脚本和正则表达式。

数据结构 — — 列表、集合、哈希表、树、图等等 — — 以及 Big O 表示法和算法复杂性。

位,字节和二进制数-如何在计算机中表示数字,以及如何操作它们。

36

您绝对应该了解算法的Big-O符号和 Big-O 估计-它是什么,它是如何使用的,为什么它很重要,如何比较两个算法的 Big-O 估计,如何为简单算法构建 Big-O 估计。

30

我觉得有点好笑,你正在寻找计算机科学科目,但发现太学术:D

无论如何,这里去,没有特定的顺序:

关系模型:Introduction to Database systems

对象方向:Object Thinking

复杂性和计算理论(想想图灵机和自动机):Introduction to theory of computation

一个小的编译器设计:The Dragon Book,虽然这可能有点过于深入您的需求。

操作系统概念:Modern operating systems

人员技能:How to win friends and influence people

团队合作:Peopleware

用户界面设计:The inmates are running the asylum

14

一些帮助我发展的概念(智力和代码):

词法,解析,字符串匹配,正则表达式

Memoization

封装 / 作用域 / 闭包

缓存

递归

迭代器 / 生成器

函数式编程-约翰 · 休斯的惊人article让我在“为什么”

这些都是离散数学的全部领域,但 CS 需要认真介绍:

矩阵 / 线性代数

图论

尽管lectures and articles by Mark Jason-Dominus经常针对 Perl 黑客,但我认为任何程序员都会从他清晰的演示和真实的代码中受益,尤其是在Higher Order Perl中。

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(392)
显示已发送消息但未接收电子邮件的联系人表单 7(contactform7)
上一篇
如何在AWSEC2中重新下载pem文件
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 59 58
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 67 78
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 96 73
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 29 77
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 88 41
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 32 42
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 18 60
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 44 56

发表评论

登录 后才能评论

评论列表(51条)