加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 为每个可能的排列填充3×3位立方体

发布时间:2020-12-16 01:28:48 所属栏目:百科 来源:网络整理
导读:我想建立一个包含位(布尔值)的3×3立方体集合.我希望该集合包含所有可能的值组合.因此,对于27位,每个位都打开或关闭的每种可能组合. var dimension = 3;var cubes = new Listbool[,]();// iterate from (0,0) to (3,3,3)var cube = new bool[dimension,dimen
我想建立一个包含位(布尔值)的3×3立方体集合.我希望该集合包含所有可能的值组合.因此,对于27位,每个位都打开或关闭的每种可能组合.

var dimension = 3;
var cubes = new List<bool[,]>();

// iterate from (0,0) to (3,3,3)
var cube = new bool[dimension,dimension,dimension];
for (int i = 0; i < dimension; i++)
{
    for (int j = 0; j < dimension; j++)
    {
        for (int k = 0; k < dimension; k++)
        {
            cube[i,j,k] = true;
        }
    }
}
cubes.Add(cube);

这将创建一个多维数据集,其中每个单元格都设置为true.如何创建所有其他多维数据集来表示每个可能的排列?

解决方法

在我看来,这里创建一个立方体的整个概念是多余的,并且在内存方面效率很低.

当你问“Nth 3×3立方体位置中的位是什么”时,你在这里问的是:“N的二进制数字是什么,27位数”.

为此,您不需要存储或计算任何东西 – 您只需要对int进行位运算(因为int是32位,而您只需要27位).所以:取int n,并使用按位运算符(&,|,>>等)的任意组合 – 就是这样 – 没有多维数据集,没有列表,没有任何东西要存储或预先计算 – 只是一个int.使用单个int的位是非常有效的 – 比从预先计算的bool [,]查找它们便宜得多.并且内存成本实际上为零,而不是预先计算选项的16GiB.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读