| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1693 人关注过本帖
标题:如何按二进制数的方式来变换多维数组里每一行的数值的变化情况。
只看楼主 加入收藏
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
结帖率:93.33%
收藏
已结贴  问题点数:15 回复次数:8 
如何按二进制数的方式来变换多维数组里每一行的数值的变化情况。
如下一段代码可以正常运行:
#include <stdio.h>
int main()
{
  int a[4][8]={0};
  int i,j,x=1;
  
  for(i=0;i<4;i++)
    { for(j=0;j<8;j++)
       printf("%d ",a[i][j]);
      printf("\n");
    }
}
运行效果如下:0 0 0 0 0 0 0 0
              0 0 0 0 0 0 0 0
              0 0 0 0 0 0 0 0
              0 0 0 0 0 0 0 0
现在想现在我想让它做一系列的变换,
第一次变成0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1

第二次变成0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
          0 0 0 0 0 0 0 0
第三次变成0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
          1 1 1 1 1 1 1 1
第四次变成0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
          0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
第五次变成0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
          0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
等等,就这样最后变成1 1 1 1 1 1 1 1
                    1 1 1 1 1 1 1 1
                    1 1 1 1 1 1 1 1
                    1 1 1 1 1 1 1 1
其实这有点像二进制数的样子。每次变换就等于二进制数加一的样子。请问,该怎么用循环控制变量的方法加以实现。
搜索更多相关主题的帖子: 二进制数 变换 数值 变化 int 
2017-12-17 21:55
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:0 
把二维数组中每一个元素和1进行^运算,在0和1之间切换,不知道是不是该这样理解
2017-12-18 09:56
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
收藏
得分:0 
不是的,你这样看啊:
把这个二维数组的第一列数横过来看,从上到下,不就是0000
                                                  0001
                                                  0010
                                                  0011
                                                  0100
                                                  0101
                                                  0110
                                            .。。。
                                                 1111
了吗。
这就像二进制一样,每变换一次,就是二进制数加一。
2017-12-18 10:47
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
收藏
得分:0 
太难了?我实在是想不出该怎么做了,愁死俺了。
2017-12-18 22:29
吹水佬
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10539
专家分:42927
注 册:2014-5-20
收藏
得分:0 
#include <stdio.h>
main()
{
    int i, j;
    for (i=0; i<16; ++i)
    {
        for (j=3; j>=0; --j)
            printf("%d\n", (i>>j)&1);
        printf("\n");
    }
}
2017-12-18 22:51
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
收藏
得分:0 
不对,我要表达的是:
第一次变成0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1

第二次变成0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
          0 0 0 0 0 0 0 0
第三次变成0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
          1 1 1 1 1 1 1 1
第四次变成0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
          0 0 0 0 0 0 0 0
          0 0 0 0 0 0 0 0
第五次变成0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
          0 0 0 0 0 0 0 0
          1 1 1 1 1 1 1 1
等等,就这样最后变成1 1 1 1 1 1 1 1
                    1 1 1 1 1 1 1 1
                    1 1 1 1 1 1 1 1
                    1 1 1 1 1 1 1 1
2017-12-19 14:01
吹水佬
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10539
专家分:42927
注 册:2014-5-20
收藏
得分:0 
回复 6楼 自学的数学
示例只显示1列。
4行8列,每列不都一样吗?
或者变通一下:
#include <stdio.h>
main()
{
    char *s[2]={"00000000","11111111"};
    int i, j;
    for (i=0; i<16; ++i)
    {
        for (j=3; j>=0; --j)
            printf("%s\n", s[(i>>j)&1]);
        printf("\n");
    }
}
2017-12-19 14:53
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
收藏
得分:0 
每一行是多个相同数,而不是一个多位数,这是二维数组,它们是不同的概念。不能变通。
2017-12-19 15:07
吹水佬
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10539
专家分:42927
注 册:2014-5-20
收藏
得分:15 
以下是引用自学的数学在2017-12-19 15:07:38的发言:

每一行是多个相同数,而不是一个多位数,这是二维数组,它们是不同的概念。不能变通。

讨论问题重点在思路,点到即止。
不能照搬,联系实际变通一下。
再变通一下:
#include <stdio.h>

void prn(int a[4][8])
{
    int i, j;
    for (i=0; i<4; ++i)
    {
        for (j=0; j<8; ++j)
            printf("%d ", a[i][j]);
        printf("\n");
    }
    printf("\n");
}

main()
{
    int a[4][8];
    int i, j, k, n;
    for (i=0; i<16; ++i)
    {
        for (j=3; j>=0; --j)
        {
            n = (i>>j)&1;
            for (k=0; k<8; ++k)
                a[3-j][k] = n;
        }
        prn(a);
    }
}
2017-12-19 15:33
快速回复:如何按二进制数的方式来变换多维数组里每一行的数值的变化情况。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017053 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved