一亩三分地

 找回密码 注册账号

扫描二维码登录本站

微信公众号
扫码关注公众号
留学申请公众号
扫码关注留学申请公众号
查看: 249|回复: 1
收起左侧

[高频题] boundary case的处理

[复制链接] |只看干货 |刷题, 高频题
我的人缘0

升级   40.5%


分享帖子到朋友圈
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (211)
 
 
0% (0)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?注册账号

x
感觉刷题最讨厌的就是处理各种boundary case二分各种左闭右开或者左右都闭(关键有时候一种写法比另一种干净很多)dp的时候跟新状态的时候有时候要加一层0 padding或者inf padding


大家知道什么好的trick可以比较好的处理这些问题么?

上一篇:theoretical computer science for leetcode?
下一篇:网络里面的 bit-synchronization 是什么机制,可以讨论下吗?
我的人缘0

升级   69%

Anonyknight 2020-10-29 10:43:49 | 显示全部楼层
本楼: 👍   100% (3)
 
 
0% (0)   👎
全局: 👍   100% (50)
 
 
0% (0)    👎
本帖最后由 Anonyknight 于 2020-10-29 10:45 编辑

边界条件有两种:
一种条件是必须加的,比如过二分的开闭, 取决与这个mid值是否有可能是答案. 如果是,>= 或者<=闭环保留mid. 边界逻辑跟其他逻辑有区别.
另外一种是处理主要逻辑的CORNER case,比如说在链表的第一个node,加dummy node, DP 的padding或者inf padding, 还有最大值初始化成-inf, 最小值初始化成inf. 都是可以减去特殊的if-else. 使主要的语句简化, 让读者容易理解.

除了多看多想,看高手大师的代码,感觉没有啥好办法.
边界条件的思考,这也是编程的核心问题,千万不要以为是简单的问题.

不然的话,Linus 也不会在TED演讲里面专门讨论编程的品味(taste) - 边界条件的处理是如何使主要逻辑简单明了.
第14分钟:
https://www.ted.com/talks/linus_ ... anguage=en#t-847648

评分

参与人数 1大米 +2 收起 理由
不知道小帅 + 2 给你点个赞!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号

本版积分规则

隐私提醒:
■拉群请前往同学同事飞友|拉群结伴版块,其他版块拉群,帖子会被自动删除
■论坛不能删帖,为防止被骚扰甚至人肉,不要公开留微信等联系方式,请以论坛私信方式发送。
■特定版块可以超级匿名:https://tools.1point3acres.com/thread
■其他版块匿名方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

手机版|||一亩三分地

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

Some icons made by Freepik from flaticon.com

快速回复 返回顶部 返回列表