老子的软件之道 - 道篇 34 ETA赞

本文通过老子《道德经》中的思想来阐述软件之道,并将这种哲学应用到企业技术架构(ETA)中。好的ETA如同道家所说的大道,既能支撑各种应用功能,又能在背后默默付出而不求回报。

      摘要:老子哲学 道德经 软件哲学、软件之道               参阅:  消灭人狼  软件的十大命题 编程规则  

      圣人曰:大道泛兮,其可左右。万物恃之以生而不辞,功成而不名有。衣养万物而不为主,常无欲可名於小。万物归焉,而不为主,可名为大。以其终不自为大,故能成其大。

      本章是老子对道的赞颂:大道能左能右、无所不至,造就万物、滋养万物却不居其功、不显其德,万物所归却不主宰它们,这就是伟大的道啊!

      按软件之道构建的企业技术架构Enterprise Technical Architecture-ETA的确具有道的特征!它就像应用系统的宽广舞台,能上能下、可左可右,各种应用功能都依托它,繁琐细碎的工作都由它去承担,它却任劳任怨豪无怨言。应用系统因为有它的支撑而获得成功,但它却不居其功、不争其荣,承载和运行着各种应用,使它们各得所需,但却不约束和限制它们,对各种技术细节处理的无微不至、细到豪颠可称为“小”啊!埋头细作、无欲无求,但所有应用都运行在它上面,真可谓“大”啊!,大而不自以为大,它具备了道的美德啊!

下载代码方式:https://pan.quark.cn/s/a4b39357ea24 依据所提供的资料,我们深入剖析此问题以及所给出的两种算法方案。 ### 问题背景 该问题源自王晓东编撰的《算法设计与实验题解》一书,书中阐述了一个值得注意的数学议题:针对一本页码从1到n顺序编号的书籍,要求统计所有页码中数字0至9各自出现的频次。例如,若n=13,则页码序列为1、2、...、13,其中数字1出现5次(体现在1、10、11、12、13中),数字0出现1次(体现在10中)。 ### 问题描述 具体而言,我们需要开发一种算法,其输入参数为一个正整数n,输出结果需为0至9这十个数字各自出现的频次。所有页码均以十进制形式呈现,且不包含任何前导零,即不会出现如006之类的页码表示。 ### 解决方案一:时间复杂度为O(n*log10(n))的算法 首先,介绍一种时间复杂度为O(n*log10(n))的算法实现。其核心构思在于遍历从1到n的每一个数值,然后逐一分解每个数值的各个位,并统计各类数字出现的频次。具体步骤如下: 1. 初始化一个长度为10的数组`count`,用于记录0至9每个数字出现的频次,初始值均为0。 2. 从1开始遍历至n,对于每一个数值i,将其转换为整数并进行以下操作: - 利用循环结构,持续将当前数值除以10,获取余数(即当前最低位的数字),并累加到对应的计数器中。 3. 遍历完成后,输出`count`数组中的每一个元素,即为所求的结果。 ### 解决方案二:优化算法 为了提升效率,提出了一种更为优越的算法。该算法基于以下观察:在1到10^n-1之间的任意区间内,每一种数字0至9出现的频次是相等的。例如,在1到999之间,每一种数字0至9出现的频次均相...
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值