对称字符串

566 篇文章

已下架不支持订阅

472 篇文章

已下架不支持订阅

141 篇文章

已下架不支持订阅

题目解析

上图所示,是第1~6个字符串,可以发现第6个已经很长了,那么本题的最多要求到第64个字符串,那么有多长呢?答:2^63,即 2^(n-1)。这个长度如果用字符串来存储的话,肯定爆内存,因此任何需要缓存字符串的动作都是禁止的。

我们只能找规律,来通过规律推导出第n个字符串的第k个字符。

那么规律是啥呢?

如上图黄框所示,我们可以发现,

第6个字符串的后半部分,和第5个字符串完全相同;

同理,

第5个字符串的后半部分,和第4个字符串完全相同;

第4个字符串的后半部分,和第3个字符串完全相同;

第3个字符串的后半部分,和第2个字符串完全相同;

第2个字符串的后半部分,和第1个字符串完全相同;

因此,如果我们要找到的 k 位于第 n 个字符串的后半部分,假设为get(n, k),那么其等价于 get(n-1, k - 2^(n-2)),按此逻辑递归,就可以一直

已下架不支持订阅

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员阿甘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值