LeetCode1238循环码排列
题目
给你两个整数 n 和 start。你的任务是返回任意 (0,1,2,,...,2n-1) 的排列 p,并且满足:
p[0] = start
p[i] 和 p[i+1] 的二进制表示形式只有一位不同
p[0] 和 p[2n -1] 的二进制表示形式也只有一位不同
思路
暴力回溯:O(n*2n)
f(s,visited,listRes)用s标识二进制的字符串
if(visited.size())==162)则可以直接返回。
加入s到结果和visited中。
找到s的邻居neib,并且neib步骤visited中:递归访问f(neib,visited,listRes)
回退:从visited和listRes中删除元素。
由于要在队尾队头操作,所以用LinkedList。
最后把得到的listRes的字符串转成十进制数字。
public List<Integer> circularPermutation(int n, int start) {
List<Integer> res=new ArrayList<>();
String biStart=Integer.toBinaryString(start);
StringBuilder stringBuilder=new StringBuilder(n);
int diffLen=n-biStart.length();
for (int i = 0; i < diffLen; i++) {
stringBuilder.append("0");
}
stringBuilder.append(biStart);
LinkedList<StringBuilder> tmpRes=new LinkedList<>();
int totalSize= (int) (Math.pow(2,n));
helper(tmpRes,stringBuilder,new HashSet<String>(),totalSize);
//把字符串转成int
for (StringBuilder stringBuilder1:tmpRes){
res.add(Integer.parseInt(stringBuilder1.toString(),2));
}
return res;
}
/**
*
* @param list
* @param stringBuilder
* @param visited
* @param totalSize
* @return 是否能成功
*/
private boolean helper(LinkedList<StringBuilder> list, StringBuilder stringBuilder, HashSet<String> visited, int totalSize) {
String str=stringBuilder.toString();
visited.add(str);
list.addLast(stringBuilder);
if(visited.size()==totalSize){
return true;
}
for (int i = 0; i < stringBuilder.length(); i++) {
//如果没有visite过,则
StringBuilder neib=new StringBuilder(stringBuilder);
char ch=stringBuilder.charAt(i);
neib.setCharAt(i,ch=='0'?'1':'0');
if(!visited.contains(neib.toString())){
if(helper(list,neib,visited,totalSize)){
return true;
}
}
}
visited.remove(str);
list.removeLast();
return false;
}
格雷码O(2N)
先生成所有格雷码,再找到开头
在一组数的编码中,若任意两个相邻的代码只有一位二进制数不同,则称这种编码为格雷码(Gray Code),
另外由于最大数与最小数之间也仅一位数不同,即“首尾相连”,因此又称循环码或反射码。
生成格雷码的方法:
先生成0~4个元素的格雷码:00,01,11,10
那么4~8的格雷码的生成方法是:在所有元素前面加上1
100,101,111,110,为了能和前四个元素接上,可以把后面这些新元素逆置,换句话说,生成元素的时候选择从后向前变量。
重点在于这种头尾相连的方式。
如果用字符串实现前置1,则需要补0,所以用数字实现更好。
List<Integer> res=new ArrayList<>();
//
int totalSize= (int) (Math.pow(2,n));
int size=2;
res.add(0);
res.add(1);
int added=2;
while(size<totalSize){
int lastSize=res.size();
for(int i=lastSize-1;i>=0;i--){
res.add(added+res.get(i));//需要补0,直接用数字表示更好
}
added<<=1;
size+=lastSize;
}
//
List<Integer> trueRes=res;
System.out.println(trueRes);
int startPoint=trueRes.indexOf(start);
List<Integer> rt=new ArrayList(trueRes.subList(startPoint,totalSize));
rt.addAll(trueRes.subList(0,startPoint));
return rt;
}
LeetCode1238循环码排列的更多相关文章
- LeetCode刷题总结-数学篇
本文总结LeetCode上有数学类的算法题,推荐刷题总数为40道.具体考点分析如下图: 1.基本运算问题 题号:29. 两数相除,难度中等 题号:166. 分数到小数,难度中等 题号:372. 超级次 ...
- 学习sql中的排列组合,在园子里搜着看于是。。。
学习sql中的排列组合,在园子里搜着看,看到篇文章,于是自己(新手)用了最最原始的sql去写出来: --需求----B, C, F, M and S住在一座房子的不同楼层.--B 不住顶层.C 不住底 ...
- [LeetCode] Arranging Coins 排列硬币
You have a total of n coins that you want to form in a staircase shape, where every k-th row must ha ...
- [LeetCode] Next Permutation 下一个排列
Implement next permutation, which rearranges numbers into the lexicographically next greater permuta ...
- js学习篇--数组按升序降序排列
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- SDOI 2016 排列计数
题目大意:一个数列A,n个元素,其中m个元素不动,其他元素均不在相应位置,问有多少种排列 保证m个元素不动,组合数学直接计算,剩余元素错位排列一下即可 #include<bits/stdc++. ...
- 排列组合算法的javascript实现
命题:从成员数为N的集合S中,选出M个元素,分别求其排列与组合结果集,即 A(N, M)与C(N, M) js解法: function queue(arr, size){ if(size > a ...
- 剑指Offer面试题:26.字符串的排列
一.题目:字符串的排列 题目:输入一个字符串,打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a.b.c所能排列出来的所有字符串abc.acb.bac.bca.cab和cba. 二 ...
- .NET平台开源项目速览(11)KwCombinatorics排列组合使用案例(1)
今年上半年,我在KwCombinatorics系列文章中,重点介绍了KwCombinatorics组件的使用情况,其实这个组件我5年前就开始用了,非常方便,麻雀虽小五脏俱全.所以一直非常喜欢,才写了几 ...
随机推荐
- Python获取随机数
Python当中,可用random模块来获取随机数 import random """ random模块,用于获取随机数 """ print ...
- Java 堆、栈、队列(遇见再更新)
目录 Java 栈.队列 栈 常用方法 案例 队列 Java 栈.队列 栈 常用方法 boolean empty() 测试堆栈是否为空 Object peek() 查看堆栈顶部的对象 Object p ...
- 03-Collection用例管理及批量执行
当我们对一个或多个系统中的很多用例进行维护时,首先想到的就是对用例进行分类管理,同时还希望对这批用例做回归测试 .在postman也提供了这样一个功能,就是Collection .通过这个Collec ...
- 【Linux】【Services】【Docker】网络
容器的网络模型: closed container: 仅有一个接口:loopback 不参与网络通信,仅适用于无须网络通信的应用场景,例如备份.程序调试等: --net none bridged co ...
- JS - 获取当前的时间,并且转换成年 - 月 - 日格式!
先获取当前时间,并转换成年月日格式! function getNowFormatDate() { var date = new Date(); var seperator1 = "-&quo ...
- HDC2021技术分论坛:进程崩溃/应用卡死,故障频频怎么办?
作者:jiwenqiang,DFX技术专家 提到开发一个产品,我们通常首先想到的是要实现什么样的功能,但是除了功能之外,非功能属性也会很大程度上影响一个产品的体验效果,比如不定时出现的应用卡死.崩溃 ...
- 云原生时代之Kubernetes容器编排初步探索及部署、使用实战-v1.22
概述 **本人博客网站 **IT小神 www.itxiaoshen.com Kubernetes官网地址 https://kubernetes.io Kubernetes GitHub源码地址 htt ...
- ZooKeeper 06 - ZooKeeper 的常用命令
目录 1 - 服务端常用命令 2 - 客户端常用命令 3 - 常用四字命令 4 - ZooKeeper 日志的可视化 版权声明 若要部署 ZooKeeper 单机环境,请查看此篇:https://ww ...
- Mac 下安装Phonegap开发环境
Mac 下安装Phonegap开发环境 2014.09.11 星期四 评论 0 条 阅读 5,613 次 作者:野草 标签:phonegap ios mac 什么是Phonegap呢?Phon ...
- 微信小程序项目使用npm安装vant-weapp的正确步骤,简单易懂!!
微信小程序项目使用npm安装vant-weapp的正确步骤 1.在当前小程序项目目录npm init -y 构建npm项目 2.运行命令 npm install vant-weapp -S --pro ...