LeetCode 2396. 严格回文的数字

2023-11-16

如果一个整数 n 在 b 进制下(b 为 2 到 n - 2 之间的所有整数)对应的字符串 全部 都是 回文的 ,那么我们称这个数 n 是 严格回文 的。

给你一个整数 n ,如果 n 是 严格回文 的,请返回 true ,否则返回 false 。

如果一个字符串从前往后读和从后往前读完全相同,那么这个字符串是 回文的 。

示例 1:

输入:n = 9
输出:false
解释:在 2 进制下:9 = 1001 ,是回文的。
在 3 进制下:9 = 100 ,不是回文的。
所以,9 不是严格回文数字,我们返回 false 。
注意在 4, 5, 6 和 7 进制下,n = 9 都不是回文的。

4 <= n <= 10 5 ^5 5

解法一:直接模拟:

class Solution {
public:
    bool isStrictlyPalindromic(int n) {
        for (int i = 2; i <= n - 2; ++i) {
            vector<int> digitArr;
            int nBak = n;
            while (nBak) {
                digitArr.push_back(nBak % i);
                nBak /= i;
            }

            int digitNum = digitArr.size();
            int loopNum = digitNum >> 1;
            for (int j = 0; j < loopNum; ++j) {
                if (digitArr[j] != digitArr[digitNum - j - 1]) {
                    return false;
                }
            }
        }

        return true;
    }
};

此算法时间复杂度为O(nlgn),空间复杂度为O(lgn)。

解法二:对于 n ≥ 5 n\geq5 n5的任何数,它在n-2进制下一定是12,不是一个严格回文的数字,对于n=4,它在2进制下是100,也不是严格回文的数字,因此结果一定是false:

class Solution {
public:
    bool isStrictlyPalindromic(int n) {
        return false;
    }
};

此算法时间复杂度为O(1),空间复杂度为O(1)。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

LeetCode 2396. 严格回文的数字 的相关文章

随机推荐

  • SpringCloud系列教程(1)--开发环境的准备

    开发环境准备 eclipse apache maven 3 5 0 jdk1 8 说明 这个是本人的开发环境工具 也可以使用自己适应的环境 比如 IntelliJ IDEA 但是本系列以eclipse来简述 如果环境不会配置 请自行百度 因
  • Android Studio TraceView性能优化分析

    http blog csdn net androiddevelop article details 8223805 http www cnblogs com sunzn p 3192231 html Android 编程下的 TraceVi
  • ConstraintLayout各种居中设置

    1 全局居中 app layout constraintBottom toBottomOf parent app layout constraintEnd toEndOf parent app layout constraintStart
  • Python基于xlrd模块处理合并单元格

    Excel是我们日常工作中经常使用的电子表格软件 它可以方便地对数据进行整理 计算和分析 在Excel中 有时候需要将多个单元格合并成一个单元格 以便更好地展示数据 但是 在数据处理过程中 合并单元格也会带来不少麻烦 本文将介绍如何使用Py
  • SpringBoot实战(八)集成 Logback

    目录 1 简介 2 项目结构 3 配置文件 3 1 Maven 3 2 logback spring xml 3 3 application yml 4 自定义输出级别 5 项目地址 6 部分内容没有输出到日志文件中问题处理 7 根据开发
  • oauth2.0--基础--6.1--SSO的实现原理

    oauth3 0 基础 6 1 SSO的实现原理 1 什么是SSO 1 1 概念 在一个 多系统共存 的环境下 用户在一处登录后 就不用在其他系统中登录 就可以访问其他系统的资源 用户环境 浏览器 只能同一个浏览器 不会出现A浏览器登录成功
  • Kafka常见的导致重复消费原因和解决方案

    点击上方蓝色字体 选择 设为星标 回复 资源 获取更多资源 大数据技术与架构 点击右侧关注 大数据开发领域最强公众号 暴走大数据 点击右侧关注 暴走大数据 问题分析 导致kafka的重复消费问题原因在于 已经消费了数据 但是offset没来
  • Android Studio 编译Library的jar包与aar包

    编译器 基于Android Studio版本为4 0 2 1 先编译一下工程 jar包 在Project模式下 jar包的位置 build intermediates compile library classes jar debug cl
  • access有效性规则不为空值_在设置access有效性规则中,大于0并且小于100怎么写?...

    展开全部 在有效性e5a48de588b662616964757a686964616f31333433633362规则处输入 gt 0 And lt 100即可 就是了 如果需要不包含0和100 那么就去掉其中的 就可以了 在有效性规则中
  • 完整的php在线加密代码,无私奉上(原创)

    以下是一个示例的完整的PHP代码 用于在网站前台输入PHP代码并生成加密后的代码
  • vue.runtime.esm.js2b0e619 [Vue warn] Error in render “TypeError Cannot read property ‘matched‘

    错误截图 踩坑原因 在配置vue router的路由时和将router实例挂载至Vue实例上时 实例名称没有按照标准 配置vue时 在配置vue router时 我们一般会将路由的映射关系抽成一个数组 就想下面这样 const routes
  • 小程序web-view 跳转到h5 监听返回按钮

    1 跳转到h5之后 先给页面堆栈 然后就可以监听到返回事件了
  • huggingface 自定义模型finetune训练测试--bert多任务

    背景 需要将bert改为多任务 但是官方仅支持多分类 二分类 并不支持多任务 改为多任务时我们需要修改输出层 loss 评测等 如果需要在bert结尾添加fc等也可以参考该添加方式 代码 修改model 这里把BertForSequence
  • MySQL之进阶查询语句

    这里写目录标题 一 按关键字排序 1 单字段升序排列 默认不指定是升序 2 单字段降序排列 3 结合where进行条件过滤 4 多字段排序 查询hp升序排列 相同hp的 id按降序排列 查询先按hp升序排列 相同分数的 id按升序排列 5
  • Golang-常见数据结构Slice

    Slice slice 翻译成中文就是切片 它和数组 array 很类似 可以用下标的方式进行访问 如果越界 就会产生 panic 但是它比数组更灵活 可以自动地进行扩容 了解 slice 的本质 最简单的方法就是看它的源码 runtime
  • llvm版本

    sudo update alternatives install usr bin llvm config llvm config usr bin llvm config 5 0 200 slave usr bin llvm ar llvm
  • RuntimeError:a leaf Variable that requires grad has been used in an in-place

    原文链接 https blog csdn net weixin 43056332 article details 115188116 记录一下训练yolov5碰到的问题 RuntimeError a leaf Variable that r
  • IP地址划分--主机号--子网号

    参考ip讲解 问题 假设一个主机的IP地址是202 112 14 137 掩码是255 255 255 224 主机IP地址的二进制表示11001010 01110000 00001110 10001001 子网掩码的二进制表示 11111
  • Vue3 + TS : Unexpected token,Did you mean `{‘}}` or `&rbrace`

    笔者今天开发的时候遇到了这样一个错误 Unexpected token Did you mean or rbrace 上述的是错误提示 如下图 问题出现的原因 问题出现的原因是因为在上图的73行 我这边做了一个类型的预测 后面获取的dom元
  • LeetCode 2396. 严格回文的数字

    如果一个整数 n 在 b 进制下 b 为 2 到 n 2 之间的所有整数 对应的字符串 全部 都是 回文的 那么我们称这个数 n 是 严格回文 的 给你一个整数 n 如果 n 是 严格回文 的 请返回 true 否则返回 false 如果一