作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试解决“给出n
和k
,产生k
-数字[1,2,...n]
的按字典顺序排列”的常见问题
当使用n > 9
时,字符串表示形式可能会有一些歧义,并且看起来很困惑,因此我尝试使用toRadixString
方法将每个数字转换为base n
。
这是我的代码:
String getPermutationFactoradic(int n, int k){
var factoradic = [for(int i = 1, j=k-1; i <= n; j=j~/i,i++) j%i].reversed.toList();
var numbers = [for(int i = 1; i <= n; i++) i];
return [for(int i = 0; i < factoradic.length; i++) numbers.removeAt(factoradic[i])].map((int num) => num.toRadixString(n)).join(' ').toUpperCase();
}
正如您在最后一行看到的那样,我正在将每个数字映射到基数为
n
的基数字符串。
print('iterative -> ${getPermutationFactoradic(16, 1996)}');
我得到的输出是这样的:
iterative -> 1 2 3 4 5 6 7 8 9 C F E A D 10 B
我的问题是,为什么返回值
10
而不是
A
?在我不知道的toRadixString方法中是否发生某些奇怪的事情?我真的很困惑这是怎么发生的。
最佳答案
您的数字从1开始,而不是0。您具有从1到n
的n
数字,并且n.toRadixString(n)
为“10”。
关于dart - toRadixString(int radix)产生奇怪的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62543324/
我正在尝试解决“给出n和k,产生k-数字[1,2,...n]的按字典顺序排列”的常见问题 当使用n > 9时,字符串表示形式可能会有一些歧义,并且看起来很困惑,因此我尝试使用toRadixString
我是一名优秀的程序员,十分优秀!