重复是可耻的

文章目录


重复是程序员最可耻的事情,系统中的每一项知识都必须具有单一,无歧义,权威的表示

重复来自于多方面:

  1. 强加的重复——开发者觉得无可选择,环境要求必须重复。

    • 对于信息在系统不同模块的重复表示,我们可以选择,单独维护信息的元数据,使用生产器在系统不同模块生成信息的不同表示。

    • 在这里插入图片描述

    • 代码与文档的重复

    • 语言导致的重复,我们在C的.h文件与.c文件中重复。使用头文件描述接口,使用.c文件描述tech details(使用者根本不care)

  2. 无意的重复——根本没有意识到
    有时候为了性能问题,而带来重复(缓存)。我们必须使得重复的影响局部化,提供给外界的接口不能重复。

  3. 无耐性的重复——偷懒,copy
    copy一个函数就能解决的问题,你愿意将两个函数重构提炼么?
    忍住这样的诱惑,牢记这种偷懒是程序员的耻辱,功利地说,欲速则不达,现在节省的几分钟,将来会损失几小时。

  4. 开发者之间的重复
    交流。
    阅读他人的源码与文档,勇敢的展示自己的源码与文档。

核心的核心:Make it easy to reuse

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
题目描述 小贝现在上六年级,正是长身体的时候,小贝的妈妈给小贝规定了每天要吃的饭量。 小贝要连续吃 n 天的饭,有 n+1 个碗,第 i 个碗的容量为 ai,所有的碗每天都会重新盛满饭。小贝妈妈规定小贝在第 i 天要吃第 i、i+1 两碗饭。而小贝的饭量有限,每天最多只能吃 k 的饭量。但是小贝妈妈永远都觉得小贝吃的不够多,以至于可能会有小贝吃不下的剩饭。 浪费粮食可耻!现在小贝请你帮他调整序列 a 变为 a′,也就是减少一些碗的容量(可以不减),使得小贝每天吃饭的总量不会超过 k。但是减去的容量总和不能太大,否则小贝妈妈会觉得小贝是故意不想吃饭。 请你回答满足条件的序列 a′,表示调整之后每个碗的容量,并且减去的容量总和要最小。 不同的碗减去的容量可以不一样,最后每个碗的容量不可以是负数! 如果有多个满足条件的序列 a′ ,则输出 字典序最大 的那一个。 假设序列 x 和序列 y 都符合要求,则序列 x 的字典序比序列 y 的字典序大,当且仅当存在一个 i 满足 1≤i≤n+1 xi>yi 对于所有的 j(1≤j<i) 均有 xj=yj 输入格式 第 1 行 2 个正整数 n,k。 第 2 行 n+1 个正整数表示序列 a。 输出格式 输出一行 n+1 个整数,表示调整后的序列 a′。 样例 Input 1 5 6 3 4 2 7 3 1 Output 1 3 3 2 4 2 1 Input 2 5 6 7 4 3 7 2 8 Output 2 6 0 3 3 2 4 数据范围 前 50% : 1≤n≤2×103 1≤ai,k≤104 后 50% : 1≤n≤2×105 1≤ai,k≤104 样例解释 第1个样例中 第2个碗容量减少了1,第4个碗容量减少了3,第5个碗容量减少了1。 总共减少了5的容量,这是最少的减少容量之和。
07-11

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值