编程到底难在哪里?

更新日期: 2018-06-20阅读: 2.5k标签: 编程

编程到底难在哪?看了下面这个买苹果的例子你就会明白……


普通人:我今天要买一斤苹果。

程序员:我今天要买一斤苹果——

因为我只喜欢红富士苹果,所以我只买红富士苹果。

我能接受的最高价格是10元/斤。

正常情况下一斤苹果用一个袋子能装下,但是为防万一,我会带两个袋子。

我知道附近的3家水果店,所以我会依次访问这3家水果店。

根据上述条件,我设计出以下的买苹果的流程:

买苹果流程开始
   对水果店0、水果店1、水果店2依次执行:
   拜访一家水果店流程开始
       走到此水果店
       如果此水果店没有开门,则结束当前的“拜访一家水果店流程”
       如果此水果店没有苹果,则结束当前的“拜访一家水果店流程”
       如果此水果店的苹果当中没有红富士苹果,则结束当前的“拜访一家水果店流程”
       如果此水果店的红富士苹果剩余不到一斤,则结束当前的“拜访一家水果店流程”
       如果此水果店的红富士苹果的价格高于10元/斤,则执行3次:
       讲价流程开始
           询问店主是否愿意将价格降到10元/斤或更低
           如果店主愿意,则跳过剩余的“讲价流程”
       讲价流程结束
       如果此水果店的红富士苹果的价格仍然高于10元/斤,则结束当前的“拜访一家水果店流程”
       打开一个袋子,将其作为当前的袋子
       重复执行以下流程,直到总重量大于一斤:
       装袋一个苹果流程开始
           从所有的不在袋子中的红富士苹果中选出最好的一个
           如果此苹果能装入当前的袋子,则将此苹果装入当前的袋子,否则执行:
           换袋子流程开始
               如果我有剩余的袋子,则从中任意选出一个并作为当前的袋子,否则执行:
               向店主要袋子流程开始
                   向店主索要一个袋子
                   如果店主拒绝给我袋子,则将我的所有袋子里的所有苹果取出,然后结束当前的“拜访一家水果店流程”
                   将店主给我的袋子作为当前的袋子
               向店主要袋子流程结束
           换袋子流程结束
           测量我的所有袋子里的所有苹果的总重量
       装袋一个苹果流程结束
       根据我的所有袋子里的所有苹果的总重量和店主给出的价格,计算我应付的价格
       向店主询问我应付的价格
       如果我不接受店主索要的价格,则执行3次:
       校对流程开始
           向店主解释我计算出的价格,并询问其是否同意
           如果店主同意,则跳过剩余的“校对流程”
       校对流程结束
       如果我仍然不接受店主索要的价格,则将我的所有袋子里的所有苹果取出,然后结束当前的“拜访一家水果店流程”
       如果我没带钱,则将我的所有袋子里的所有苹果取出,然后结束当前的“拜访一家水果店流程”
       付钱拿走苹果
       跳过剩余的“拜访一家水果店流程”
   拜访一家水果店流程结束
买苹果流程结束  


这个流程怎么样?我来设计一些测试样例,测试一下这个流程。

测试发现一个问题:如果水果店0和水果店1都有红富士苹果并且价格都低于10元/斤,而且水果店1的价格比水果店0更低,那么我希望买水果店1的苹果,但我设计的流程会让我买水果店0的苹果。

为了解决这个问题,我应该先询问所有水果店的价格,然后去价格最低的那一家买苹果。经过修改,我重新设计出以下的买苹果的流程:

买苹果流程开始
   对水果店0、水果店1、水果店2依次执行:
   询问一家水果店的红富士价格流程开始
       走到此水果店
       如果此水果店没有开门,则视此水果店的红富士价格为无穷大元/斤,并结束当前的“询问一家水果店的红富士价格流程”
       如果此水果店没有苹果,则视此水果店的红富士价格为无穷大元/斤,并结束当前的“询问一家水果店的红富士价格流程”
       如果此水果店的苹果当中没有红富士苹果,则视此水果店的红富士价格为无穷大元/斤,并结束当前的“询问一家水果店的红富士价格流程”
       如果此水果店的红富士苹果剩余不到一斤,则视此水果店的红富士价格为无穷大元/斤,并结束当前的“询问一家水果店的红富士价格流程”
       向店主询问此水果店的红富士苹果价格并记录
   询问一家水果店的红富士价格流程结束
   从3家水果店中选出红富士价格最低的一家(如果有并列则随机选择),将其作为目标水果店
   如果目标水果店的红富士苹果价格为无穷大元/斤,则结束当前的“买苹果流程”
   走到目标水果店
   如果此水果店的红富士苹果的价格高于10元/斤,则执行3次:
   讲价流程开始
       询问店主是否愿意将价格降到10元/斤或更低
       如果店主愿意,则跳过剩余的“讲价流程”
   讲价流程结束
   如果此水果店的红富士苹果的价格仍然高于10元/斤,则结束当前的“买苹果流程”
   打开一个袋子,将其作为当前的袋子
   重复执行以下流程,直到总重量大于一斤:
   装袋一个苹果流程开始
       从所有的不在袋子中的红富士苹果中选出最好的一个
       如果此苹果能装入当前的袋子,则将此苹果装入当前的袋子,否则执行:
       换袋子流程开始
           如果我有剩余的袋子,则从中任意选出一个并作为当前的袋子,否则执行:
           向店主要袋子流程开始
               向店主索要一个袋子
               如果店主拒绝给我袋子,则将我的所有袋子里的所有苹果取出,然后结束当前的“买苹果流程”
               将店主给我的袋子作为当前的袋子
           向店主要袋子流程结束
       换袋子流程结束
       测量我的所有袋子里的所有苹果的总重量
   装袋一个苹果流程结束
   根据我的所有袋子里的所有苹果的总重量和店主给出的价格,计算我应付的价格
   向店主询问我应付的价格
   如果我不接受店主索要的价格,则执行3次:
   校对流程开始
       向店主解释我计算出的价格,并询问其是否同意
       如果店主同意,则跳过剩余的“校对流程”
   校对流程结束
   如果我仍然不接受店主索要的价格,则将我的所有袋子里的所有苹果取出,然后结束当前的“买苹果流程”
   如果我没带钱,则将我的所有袋子里的所有苹果取出,然后结束当前的“买苹果流程”
   付钱拿走苹果
买苹果流程结束  


现在这个流程是不是完美了呢?不是,我还能发现很多问题。

如果3家水果店都有红富士苹果但都不到一斤,但是三家店加起来能达到一斤,那么我不应该结束流程回家,而是应该把三家店的红富士苹果都买下来。

如果我向水果店询问价格的时候这家店还有红富士苹果,但我询问完所有水果店的价格后这家店的红富士苹果卖完了,那么我的流程会让我试图处理不存在的红富士苹果。

我走路的过程中可能会遇到突发事件,比如发现了新的水果店,比如袋子破掉了苹果掉一地,对于这些情况我的流程都无法进行处理。

啊问题太多了我懒得再改流程了。我还是去X宝买吧。
那么接下来我要设计一个在X宝买红富士苹果的流程……  


这篇回答并不是讲述在生活中程序员如何买苹果,而是以买苹果为例说明程序员如何解决问题。程序员需要对问题进行透彻的分析,理清其涉及的所有细节,预测可能发生的所有意外与非意外的情况,列出解决方案的所有步骤,以及对解决方案进行尽量全面的测试。而这些正是我认为编程难的地方。任何一点遗漏都会成为bug,轻则导致挨骂,重则导致经济损失甚至危害安全。注意这些难点全部和语言无关。和编程所需要的绝对严密的逻辑相比,语言实在是太简单了。(某些自带代码混淆效果的语言除外)



作者:DJ Hitori
出处:知乎
链接:https://www.zhihu.com/question/22508677

链接: https://www.fly63.com/article/detial/886

程序员的笔记,编程写软件学到的 7 件事

如果你真的做出了一些东西,在面对那些令人眼花缭乱的理论知识,或是和你相似甚至比你做的更糟糕的人时大可不必谦虚。在一天结束之时,正是那些在战壕中的开发者——构建、测试和开发了代码的人,真正做了事情。

自学编程的六个技巧总结

这些事情可以帮助新手在他们漫长的旅程中学习编程。我知道我还有更多东西需要学习,并将继续学习如何永远地学习。最重要的事情说三遍,请继续,不要放弃,不要放弃,不要放弃。

谈谈Javascript异步代码优化

Javascript代码异步执行的场景,比如ajax的调用、定时器的使用等,在这样的场景下也经常会出现这样那样匪夷所思的bug或者糟糕的代码片段,那么处理好你的Javascript异步代码成为了异步编程至关重要的前提

Blockly - 来自Google的可视化编程工具

Google Blockly 是一款基于Web的、开源的、可视化程序编辑器。你可以通过拖拽块的形式快速构建程序,而这些所拖拽的每个块就是组成程序的基本单元。可视化编程完成

我真是受够编程了

成为伟大的程序员,需要付出许多编程之外的努力。我们的大脑是有限的,每天要应付的问题复杂到足以让人精神崩溃。当工作不顺利时,多少都会有些冒名顶替症候群的感觉。

前端的编程软件哪些比较好用?

推荐8款最好用的前端开发工具供美工或者前端开发人员使用,当然若你是NB的全栈工程师也可以下载使用。Web前端开发最常见的编程软件有以下几种: 在前端开发中,有一个非常好用的工具,Visual Studio Code,简称VS code

如何保持学习编程的动力

学编程现在看起来挺简单,因为网上有丰富的各种资源。然而当你实际去学的时候就发现,还是很难!对我来说也一样。但从某天起,我决定认认真真学编程一年。后来又过了一年,又过了一年又一年……我好像有点感悟。

编程小技巧

命名最好遵循驼峰法和下划线法,并且要清楚的表达变量的意思。相对于驼峰法而言,我更喜欢下划线法。下划线法可以更清楚的看出这个变量表示的意思。比如aBigGreenBanana和一个a_big_green_banana。

CSS并不是真正的编程语言

每隔几个月就会出现一篇文章表明:CSS并不是真正的编程语言。以编程语言的标准来说,CSS过于困难。使用这门语言会很有创造性:事实确实如此,CSS不同于传统的编程,且具有缺陷,同任何标准化编程语言相比

自学编程的朋友,我想给你们这 5 个建议

很多人都想转行互联网,不管是出于兴趣、行业前景还是薪资的考虑,我想给那些自学编程的人的一些建议,自学编程不易,千万要想清楚了再开始,特别是想要转行,做程序员,以此谋生的那些人,一定要慎重。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!