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, 让我们把这个二进制 ... 
随机推荐
- Linux - Shell - 算数表达式 - 关系运算
			概述 shell 中基于 $(()) 的 关系运算 背景 复习 shell 脚本 凑数吧 准备 环境 os centos7 1. 位运算 代码 #!/bin/bash # 关系运算符 # 结果是 真/ ... 
- python 百万级别类实例实现节省内存
			# 案例: ''' 某网络游戏中,定义了玩家类Player(id,name,status) 每当有一个玩家,就会在服务器创建一个Player实例 当在线人数过多时,将产生大量实例(百万级别),消耗内存 ... 
- 整理收集的一些常用java工具类
			1.json转换工具 package com.taotao.utils; import java.util.List; import com.fasterxml.jackson.core.JsonPr ... 
- Django框架介绍(二)
			1.MVC框架和MTV框架 MVC全名model view controller,是软件工程中的一种软件架构模式,把软件分为三个基本部分:模型(model).视图(view)和控制器(controll ... 
- AcWing 338. 计数问题
			#include <iostream> #include <algorithm> #include <vector> using namespace std; ; ... 
- pikaqiu练习平台(XSS(跨站脚本))
			XSS(跨站脚本)概述 Cross-Site Scripting 简称为“CSS”,为避免与前端叠成样式表的缩写"CSS"冲突,故又称XSS.一般XSS可以分为如下几种常见类型: ... 
- jenkins常用
			记最精简版的启动:gradle集成springboot+vue 安装jenkins,安装待推荐插件 服务器安装gradle 服务器安装npm 配置git仓库,配置git开发者账号等 配置gradle构 ... 
- 解决for循环插入同一元素无法重复插入问题
			var el = document.createElement("div"); el.appendChild(document.createTextNode("hello ... 
- Lingo简单入门,以及对线性规划做敏感性分析设置
			Lingo中用!表示注释,注释结束用;表示,lingo不区分大小写,运行时会自动统一装换成大写 编程步骤: 1.推算出正确的模型 2.确定描述集,定义集合 3.确定变量 4.正确写出每个式子 常用函数 ... 
- angularJS 十六进制与字符串相互转换
			angular 将字符串数据转换为十六进制数据 /** * @Description: TODO 字符串转16进制方法 * @author wjw * @date 2019年9月18日16:35:32 ... 
