跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
C++算法

AcWing 1152 格雷码:递归与位运算解析

格雷码是一种特殊的 n 位二进制串排列法,要求相邻的两个二进制串间恰好有一位不同。本题要求给定 n 和 k,求出按特定算法生成的 n 位格雷码中的 k 号二进制串。解题核心在于利用格雷码的递归构造规律:n+1 位格雷码由 n 位格雷码顺序加前缀 0 和逆序加前缀 1 组成。通过判断 k 是否超过总数的一半,确定当前位的值并递归求解剩余部分。代码使用 unsigned long long 防止溢出,时间复杂度为 O(n)。

佛系玩家发布于 2026/3/15更新于 2026/6/1321 浏览
AcWing 1152 格雷码:递归与位运算解析

AcWing 1152 格雷码

题目描述

通常,人们习惯将所有 n 位二进制串按照字典序排列。格雷码(Gray Code)是一种特殊的 n 位二进制串排列法,它要求相邻的两个二进制串间恰好有一位不同,特别地,第一个串与最后一个串也算作相邻。

n 位格雷码不止一种,下面给出其中一种格雷码的生成算法:

  1. 1 位格雷码由两个 1 位二进制串组成,顺序为:0, 1。
  2. n + 1 位格雷码的前 2^n 个二进制串,可以由依此算法生成的 n 位格雷码按顺序排列,再在每个串前加一个前缀 0 构成。
  3. n + 1 位格雷码的后 2^n 个二进制串,可以由依此算法生成的 n 位格雷码按逆序排列,再在每个串前加一个前缀 1 构成。

综上,n + 1 位格雷码,由 n 位格雷码的 2^n 个二进制串按顺序排列再加前缀 0,和按逆序排列再加前缀 1 构成,共 2^{n+1} 个二进制串。

对于 n 位格雷码中的 2^n 个二进制串,按上述算法得到的排列顺序将它们从 0 ~ 2^n - 1 编号。

现在给出 n, k,请你求出按上述算法生成的 n 位格雷码中的 k 号二进制串。

输入输出

输入

仅一行,包含两个整数 n 和 k。

输出

仅一行,一个 n 位二进制串表示答案。

样例

输入:

2 3 

输出:

10 

代码实现

#include<bits/stdc++.h>
using namespace std;

// 使用 unsigned long long,因为 k 可能很大(最大 2^64-1)
typedef unsigned long long ULL;

// 递归函数:查找 n 位格雷码中序号为 k 的格雷码
// 参数:n - 格雷码的位数,k - 要查找的格雷码序号(从 0 开始)
// 返回值:序号为 k 的 n 位格雷码的二进制字符串
string find(int n, ULL k){
    // 递归基:当 n=0 时,返回空字符串
    if (n == 0){
        return "";
    }
    // 计算 n 位格雷码总数的一半
    // 对于 n 位格雷码,总共有 2^n 个,一半是 2^(n-1) 个
    ULL len = (1ULL << (n - 1));
    
    // 情况 1:k 在前半部分(0 到 len-1)
    
     (k < len){
        
        
          + (n - , k);
    }  {
        
        
        
        
        
          + (n - , len *  -  - k);
    }
}

{
     n; 
    ULL k; 
    cin >> n >> k;
    
    cout << (n, k) << endl;
     ;
}
// 此时格雷码的第一位是'0'
if
// 递归求解 n-1 位格雷码,序号为 k
// 在前面添加'0'
return
"0"
find
1
else
// 情况 2:k 在后半部分(len 到 2^n-1)
// 此时格雷码的第一位是'1'
// 递归求解 n-1 位格雷码,序号需要对称映射
// 映射规则:后半部分的序号 k 映射为前半部分的序号 (len*2-1-k)
// 在前面添加'1'
return
"1"
find
1
2
1
int main()
int
// 格雷码的位数
// 要查找的格雷码序号(从 0 开始)
// 输出序号为 k 的 n 位格雷码
find
return
0

目录

  1. AcWing 1152 格雷码
  2. 题目描述
  3. 输入输出
  4. 输入
  5. 输出
  6. 样例
  7. 代码实现
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • Erupt 低代码框架基于 Java 注解的企业级应用开发方案
  • 基于 MCP 协议集成 Codebuddy CLI 与腾讯云 Lighthouse 实战
  • 双指针算法进阶:从三角形计数到四数之和
  • ComfyUI 与 Photoshop 深度集成:插件部署与工作流配置
  • Kotlin 协程 Continuation 原理与挂起函数实现
  • C++ 优先队列(Priority Queue)详解与实战
  • Python 动态图表制作指南:基于 Matplotlib FuncAnimation
  • Clawdbot 对接企业微信单向推送全流程指南
  • DeepSeek 系列模型版本演进与优缺点深度解析
  • 银河麒麟服务器版 Nginx Web 服务部署实战
  • EasyOCR 使用指南:Python 开源 OCR 工具图文识别实战
  • C++ 网络编程入门:TCP 协议下的简易计算器项目
  • FPGA 以太网 UDP 通信实现与实战
  • 使用动态规划求解斐波那契数列
  • 默认安全治理实践:水平越权检测与前端安全防控
  • OpenClaw Docker 部署教程:飞书/钉钉/QQ 机器人集成
  • Linux 高级 IO:I/O 多路转接 select 接口原理与 TCP 服务器实现
  • Mac Mini 部署 OpenClaw 智能体实战指南
  • ToDesk ToClaw 评测:零门槛体验 OpenClaw 级 AI 自动化
  • NopeCHA Node.js 库核心功能与使用示例详解

相关免费在线工具

  • 加密/解密文本

    使用加密算法(如AES、TripleDES、Rabbit或RC4)加密和解密文本明文。 在线工具,加密/解密文本在线工具,online

  • Gemini 图片去水印

    基于开源反向 Alpha 混合算法去除 Gemini/Nano Banana 图片水印,支持批量处理与下载。 在线工具,Gemini 图片去水印在线工具,online

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online

  • Markdown转HTML

    将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML转Markdown 互为补充。 在线工具,Markdown转HTML在线工具,online

  • HTML转Markdown

    将 HTML 片段转为 GitHub Flavored Markdown,支持标题、列表、链接、代码块与表格等;浏览器内处理,可链接预填。 在线工具,HTML转Markdown在线工具,online