2019CSP-S T1格雷码
题目大意:
格雷码(Gray Code)是一种特殊的 nn 位二进制串排列法,它要求相邻的两个二进制串间恰好有一位不同,特别地,第一个串与最后一个串也算作相邻。
nn 位格雷码不止一种,下面给出其中一种格雷码的生成算法:
- 11 位格雷码由两个 11 位二进制串组成,顺序为:00 ,11 。
- n+1n+1 位格雷码的前 2n2n 个二进制串,可以由依此算法生成的 nn 位格雷码(总共 2n2n 个 nn 位二进制串)按顺序排列,再在每个串前加一个前缀 00 构成。
- n+1n+1 位格雷码的后 2n2n 个二进制串,可以由依此算法生成的 nn 位格雷码(总共 2n2n 个 nn 位二进制串)按逆序排列,再在每个串前加一个前缀 11 构成。
综上,n+1n+1 位格雷码,由 nn 位格雷码的 2n2n 个二进制串按顺序排列再加前缀 00 ,和按逆序排列再加前缀 11 构成,共 2n+12n+1 个二进制串。另外,对于 nn 位格雷码中的 2n2n 个 二进制串,我们按上述算法得到的排列顺序将它们从 0∼2n−10∼2n−1 编号。
现在给出 nn ,kk ,请你求出按上述算法生成的 nn 位格雷码中的 kk 号二进制串。
1≤n≤64,0<k<2n
签到题,可惜自己是菜鸡只会无脑做法..进行一个二分的过程,注意到题目中说的逆序,顺序,所以要加一个标记(表示下次添数的方法)。根据标记,在后半段的话添1(0),前半段添0(1)。
不开unsigned long long见祖宗!只有60分!
#include <bits/stdc++.h>
using namespace std;
unsigned long long n,k;
unsigned long long fpow(unsigned long long a,unsigned long long b)
{
unsigned long long ans=;
for(;b;b>>=)
{
if(b&)ans=ans*a;
a=a*a;
}
return ans;
}
int main()
{
cin>>n>>k;
vector<char>v;
bool pd=true;//true为 0000 1111等 false为1111 0000
while(n)
{
if(k>=fpow(,n)/)
{
if(pd)v.push_back('');
else v.push_back('');
k-=fpow(,n)/;
n--;
pd=false;
}
else
{
if(pd)v.push_back('');
else v.push_back('');
n--;
pd=true;
}
}
int i;
for(i=;i<v.size();i++)
{
putchar(v[i]);
}
}
2019CSP-S T1格雷码的更多相关文章
- 2019CSP day1t1 格雷码
题目描述 通常,人们习惯将所有 \(n\) 位二进制串按照字典序排列,例如所有 \(2\) 位二进制串按字典序从小到大排列为:\(00,01,11,10\). 格雷码(\(Gray Code\))是一 ...
- [LeetCode] Gray Code 格雷码
The gray code is a binary numeral system where two successive values differ in only one bit. Given a ...
- BZOJ1081[SCOI2005]超级格雷码
Description 著名的格雷码是指2n个不同n位二进制数(即0~2n-1,不足n位在前补零)的一个排列,这个排列满足相邻的两个二进制数的n位数字中最多只有一个数字不同(例如003和001就有一个 ...
- 格雷码原理与Verilog实现
格雷码原理 格雷码是一个叫弗兰克*格雷的人在1953年发明的,最初用于通信.格雷码是一种循环二进制码或者叫作反射二进制码.格雷码的特点是从一个数变为相邻的一个数时,只有一个数据位发生跳变,由于这种特点 ...
- FPGA学习笔记之格雷码、边沿检测、门控时钟
一.格雷码 格雷码的优点主要是进位时只有一位跳变,误码率低. 1.二进制转格雷码 我们观察下表: 二进制码 格雷码 00 00 01 01 10 11 11 10 二进制码表示为B[],格雷码表示为G ...
- LeetCode:Gray Code(格雷码)
题目链接 The gray code is a binary numeral system where two successive values differ in only one bit. Gi ...
- c++实现gray code(格雷码)
今天别人问的一道题,强调用分治法实现 =.= 百度了一下格雷码,然后写了一下. 关于格雷码大家看百度的吧,特别详细,贴个图: 代码如下(header_file.h是我自己写的一个头文件,包括常见的ve ...
- 产生n位元的所有格雷码
原文链接:http://blog.csdn.net/beiyeqingteng/article/details/7044471 问题:产生n位元的所有格雷码. 格雷码(Gray Code)是一个数列集 ...
- Gray code---hdu5375(格雷码与二进制码,普通dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5375 题意就是:给你一串二进制码,里面可能含有'?'这个既可以表示0又可以表示1, 让我们把这个二进制 ...
随机推荐
- 题解【洛谷P1352】没有上司的舞会
题面 题解 树形\(\text{DP}\)入门题. 我们设\(dp[i][0/1]\)表示第\(i\)个节点选\(/\)不选的最大快乐指数. 状态转移方程: \(dp[i][0]=a[i]+\sum_ ...
- 自己动手系列----使用数组实现一个简单的Set
Set:注重独一无二的性质,该体系集合可以知道某物是否已近存在于集合中,不会存储重复的元素用于存储无序(存入和取出的顺序不一定相同)元素,值不能重复.主要有HashSet和TreeSet两大实现类. ...
- 在多租户(容器)数据库中如何创建PDB:方法4 克隆远程Non-CDB
基于版本:19c (12.2.0.3) AskScuti 创建方法:克隆远程Non-CDB(从 Non-CDB 中进行远程克隆).将 非CDB数据库PROD1 远程克隆为 CDB1 中的 PDB7 对 ...
- centos7 walle2瓦力部署教程
项目部署上线,如果是单服务器,那么有多种方式可以部署,比如直接ftp上传,或者直接git去拉取,人工操作也不会花费精力和时间,但是如果采用了集群模式,有多台服务器,那么依靠一台一台的去上传代码,就显得 ...
- Spring AOP操作action时无法注入,报NullPointer异常
Spring AOP操作action时无法注入,报NullPointer异常当使用Spring AOP对action层进行操作时,会出现注入失败的问题,出现空指针异常.原因是一般struts2+spr ...
- mysql(5):主从复制和分库分表
主从复制集群 概念:主从复制是指数据可以从一个MySQL数据库服务器主节点复制到一个或多个从节点. 使用场景: 读写分离:使用主从复制,让主库负责写,从库负责读,这样,即使主库出现了锁表的情景,通过读 ...
- Java-POJ1008-Maya Calendar
题意:两种纪年方法的转换 水题,根据题目翻译成代码就可以了 居然WA了一次,避坑,output要先输出数据组数,痛心疾首啊!本来可以一次AC的. package poj.ProblemSet; imp ...
- codeforce F - Three Paths on a Tree
F. Three Paths on a Tree time limit per test 2 seconds memory limit per test 256 megabytes input sta ...
- Intellij-Idea使用小细节
SpringMVC项目部署到tomcat中文乱码,tomcat的配置里面加上 -Dfile.encoding=UTF-8
- mysql 同时支持多少连接MYSQL 查看最大连接数和修改最大连接数
MySQL查看最大连接数和修改最大连接数 1.查看最大连接数 show variables like '%max_connections%'; 2.修改最大连接数 set GLOBAL max_con ...