- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试做一个一维的 Convay 生命游戏程序,但该程序会在每次经过一代时继续生成一个额外的数字。代码:
int generation=IntegerparseInt(in.nextLine().trim());
long cells=Long.parseLong(input1, 2);
for(int i=0;i<generation;i++)//Assume
{
long newa=cells>>1;
long newb=cells<<1;
System.out.println(Long.toBinaryString(newb));//For testing purpose
cells=newa^newb;
System.out.println(Long.toBinaryString(cells));//For testing purpose
}
像这样输入
3
01011
(3代)我得到这样的输出
10110
10011
100110
101111
1011110
1001001
期望的输出是
10110
00011
00110
10111
01111
01011
编辑:将测试代码更改为:
for(int i=0;i<generation;i++)
{
long newa=cells>>1;
long newb=cells<<1;
System.out.println(Long.toBinaryString(newb));
System.out.println(Long.toBinaryString(newa));
cells=newa^newb;
System.out.println(Long.toBinaryString(cells));//For testing purpose
}
输出是:
10110
101
10011
100110
1001
101111
1011110
10111
1001001
最佳答案
正如安德鲁所说,左移总是会产生一个额外的数字。这实际上是一个正确的实现,因为康威生命游戏发生在无限的宇宙中。但是,如果你想限制宇宙的大小,你只需要保留每一代最右边的 N 个数字,其中 N 是你的宇宙的大小。
如 this answer 中所述,可以通过操作K&((1<<N)-1)
获得整数K的最右边的N个数字
完整的工作示例:
public class ConwaysGame {
public static void main(String[] args) {
int numGenerations = 10;
// Size of the "universe"
int universeSize = 12;
// Initial value
long cells = 29;
for(int i=0;i<numGenerations;i++) {
// Calculate new generation
long newa=cells>>1;
long newb=cells<<1;
cells=newa^newb;
// Limit the result to the size of the universe
cells = rightMostBits(cells, universeSize);
// Output to console
System.out.println(
leftPadZeros(
Long.toBinaryString(cells), universeSize
)
);
}
}
private static long rightMostBits(long data, int numBits){
// https://stackoverflow.com/questions/2798191/extracting-rightmost-n-bits-of-an-integer
return data & ((1<<numBits)-1);
}
private static String leftPadZeros(String str, int len){
int numzeros = Math.max(len - str.length(), 0);
return new String(new char[numzeros]).replace("\0", "0") + str;
}
}
输出:
000000110100
000001110010
000011011101
000111010100
001101000010
011100100101
110111011000
110101011100
110000010110
111000100111
关于java - 错误 : Getting an extra digit in bitwise operation,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42033105/
我正在将 ansible 合并到我们的内部 RHN 卫星中。我有来自 Red Hat 的完全更新的 RHEL 7 基础 repo 、附加、补充、可选和 RHN 工具。当我们需要它们时,我还会将选定的包
我尝试将一些值发送到另一个 Activity 。 recyclerView.addOnItemTouchListener(new RecyclerTouchListener(getApplicatio
我有这个代码: Intent intent = new Intent(); intent.setAction(Intent.ACTION_PICK); intent.s
几天前,我一直在努力寻找一种方法来为我的闹钟使用自定义 Intent 。虽然我得到了明确的答案,但我必须根据一些唯一的 ID 来定制 Intent,例如。 setAction()还是有一些问题。 我这
通知正在提供旧值。我阅读了 stackoverflow 链接,但仍然不适合我: Notification passes old Intent Extras 我有一个 Activity A。当我在 Ac
我想写以下内容: result = [] for x in list(range(10)): if x%2 != 0: for a in [1,2]:
我在使用 mysql 5.5.12 时遇到了 Amazon RDS 的 IO 性能问题。有 2 种实例类型相似且价格接近: 超大数据库实例:15 GB 内存、8 个 ECU(4 个虚拟核心,每个 2
这里是 Android 的新手,我正在与一位资深人士就 bundle 和 Intent 进行辩论。这就是我一直在做的...... Intent intent = new Intent(this, Ta
我使用的是MinGW+MSYS, 我添加了 extra-include-dirs、extra-lib-dirs,但似乎没有任何东西可以帮助 cabal 找到 PCRE 库。以下是我尝试过的一些命令行,
我已将 CVS 中的一个模块 check out 到新安装的 Windows 7 计算机上。病毒扫描程序尚未安装。 后来,当我尝试进行更新时,收到以下错误消息: 无法将文件 CVS/Entries.E
Alpine镜像中的telnet在3.7版本后被转移至busybox-extras包中,需要使用apk单独安装。 现象 Alpine版本为3.8, 不再有指向busybox的telent
对lazy="extra"究竟能做什么,有没有很好的解释? 我看过的所有帖子都只是重复了一个事实,即它会引用 MyObject.ItsCollection.Count进入 select count(*
这个问题已经有答案了: Two semicolons inside a for-loop parentheses (4 个回答) Endless loop in C/C++ [closed] (12
我的包为包含的额外内容返回空字符串。不是 NPE,是实际的“空”值。关于为什么会发生这种情况的任何想法? 新 bundle String u = nul
在 es6 中,以下似乎是有效代码: function test(a1,{a=1,b=2} = {},) {} 注意函数参数中额外的,。我不确定这是否是一个错误,因为这个额外的 , 仅适用于解构分配。
我正在查看一个包含 .myClass a.extra{...} 和 .myClass a.extra:hover{...} 的 css 模板“额外”是什么意思? 最佳答案 extra 是类名。 因为你
我来自 Web 开发的前端世界,我们非常努力地尝试限制发出的 HTTP 请求的数量(通过合并 css、js 文件、图像等)。 对于数据库连接 (MySQL),显然您不希望有不必要的连接,但作为一般规则
问题是关于包含不必要的 header 以避免在子文件中多次调用它。这是场景,我有几个文件: srlogger.h srinterface.h srinterface.cc #include #inc
我有一个程序表现出奇怪的行为 #include #include using namespace std; class man{ int i ; public:
本文整理了Java中org.threeten.extra.YearQuarter类的一些代码示例,展示了YearQuarter类的具体用法。这些代码示例主要来源于Github/Stackoverflo
我是一名优秀的程序员,十分优秀!