123
返回列表 发新帖
楼主: dshao
跳转到指定楼层
上一主题 下一主题
收起左侧

骨骼跪经

全局:
试着解下第一题:
1. 首字母对齐其实相当于 每行 word的数目一致(除最后一行以外),如楼主给的提示所示,要么每行1个,要么2个,要么 3个……
2. 每行最少 1个单词 (最长的那个word 占据了 k 个位置),最多 把所有单词都排下
3. 因此可以试着 2分每行word的数目 (1最小,所有单词数目最大),尝试查找 k 列能容纳下的最多的 word 个数
4. 假设 我们想 使得每行容纳 m 个单词,则从第一个单词开始,循环 m 次,求得m个单词能否装进 k 列 (需要注意除最后一个单词外,前 m -1 个单词后面要多加一个空格),判断m 装好了以后是否 <= k
5. 如果上述判断不成立,则m 太大,二分的 hi = mid; 如果上述 判断 true,则 m 略小,还可继续装下更多的单词,二分的 lo = mid
6. 找到最大 m 后,单词数目 / m + 1 即可
回复

使用道具 举报

全局:
daydreamerlee 发表于 2018-2-8 03:41
试着解下第一题:
1. 首字母对齐其实相当于 每行 word的数目一致(除最后一行以外),如楼主给的提示所示 ...

汗,看错题了。

第五步判断的时候要稍微复杂一点,下一个word 选择 则是 i + 行数(总单词数 / m)
回复

使用道具 举报

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

本版积分规则

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