查看: 1279| 回复: 3
跳转到指定楼层
上一主题 下一主题
收起左侧

[CareerCup] 【第三轮】8.3-8.9 CareerCup 9.7

全局:

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

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

x
9.7 Implement the "paint fill" function that one might see on many image editing programs. That is, given a screen (represented by a two-dimensional array of colors),
a point, and a new color, fill in the surrounding area until the color changes from the original color.




回复解法可以按照以下格式来



【解题思路】
【时间复杂度】
【空间复杂度】
【gist link】
---------------OPTional,如果觉得test case比较好,欢迎写出来分享----------------------
【test case】


上一篇:【第三轮】8.3-8.9 CareerCup 9.6
下一篇:【第三轮】8.3-8.9 CareerCup 9.8
全局:
【解题思路】
depth first search
for each pixel which need to be changed color, search its four neighbors


【时间复杂度】
O(mn)


【空间复杂度】
O(mn)


【gist link】
https://gist.github.com/happyWinner/3e03b08e8c394bdfdb4d

回复

使用道具 举报

🔗
grassgigi 2014-8-17 11:40:15 | 只看该作者
全局:
【解题思路】
Start from the point, recursively trying to fill in both four directions
* check if the point is valid(not out of range)
* check if color is same as the color we want to change from.
* track where is the previous position prevent back tracking

【时间复杂度】
O(X*Y)

【空间复杂度】
O(1)

【gist link】
https://gist.github.com/chrislukkk/cc3970a0f22c06443b08
回复

使用道具 举报

🔗
bitcpf 2014-9-22 01:00:05 | 只看该作者
全局:
【解题思路】
Start from the input point,
1. check if the point in the screen (x,y range)
2. check if the point match the old color
return if the point does not qualify
change the point's color
move to the 4 directions
【时间复杂度】
O(M*N)
【空间复杂度】
O(1)
【gist link】
https://gist.github.com/bitcpf/7b984da0cdb9b34de7a5
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

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