代码拉取完成,页面将自动刷新
// Time: O(l)
// Space: O(l)
class Solution {
public:
string nearestPalindromic(string n) {
const auto l = n.size();
unordered_set<long long> candidates;
candidates.emplace(static_cast<long long>(pow(10, l)) + 1);
candidates.emplace(static_cast<long long>(pow(10, l - 1)) - 1);
auto prefix = stol(n.substr(0, (l + 1) / 2));
for (long long i = -1; i <= 1; ++i) {
auto p = to_string(prefix + i);
auto pp = p + string(p.rbegin() + (l % 2), p.rend());
candidates.emplace(stol(pp));
}
long long num = stol(n), closest_val = numeric_limits<long long>::max();
candidates.erase(num);
for (const auto& val : candidates) {
if (abs(val - num) < abs(closest_val - num)) {
closest_val = val;
} else if (abs(val - num) == abs(closest_val - num)) {
closest_val = min(closest_val, val);
}
}
return to_string(closest_val);
}
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。