Matlab Central Cody Problem 4

Problem 4. Make a checkerboard matrix

Given an integer n, make an n-by-n matrix made up of alternating ones and zeros as shown below. The a(1,1) should be 1.

Example:

Input n = 5

Output a is [1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1]1

2

3

4

5

6

这应该是一个很简单的问题了,让1和0交替排列在矩阵当中,形成一个棋盘,可是没想到自己一开始也没能做出来,在网上搜了一下看到有如下的思路,记录下来供自己复习使用,下面展示一下代码。

function a = checkerboard(n)

a = ones(n); %首先建立一个n*n的方阵,里面都是1

a(1:2:end,2:2:end) = 0;%先由奇数行入手,从第二列开始依次把0放置在需要的位置

a(2:2:end,1:2:end) = 0;%接着由偶数行入手,从第一列开始依次把0放置在需要的位置上

end1

2

3

4

5

交上答案之后会弹出一个size,额,也不知道是啥意思,这个题的leading size是7,那这个46的size还是挺大的,肯定还是有更轻量的代码可以用来解决这个问题,之后有新发现后继续记录下来✊

65f2daa19817104be2d65c7e32be9f07.png

【Problem 4. 后续】

上述的代码中之所以首先建立了一个ones(n)的矩阵是因为在答题的默认代码中,就保有了这样一段提示,后来通过看别人的代码发现其实以0矩阵为初始状态会更加方便,代码展示如下。

function a = checkerboard(n)

a = zeros(n); %首先建立一个n*n的方阵,里面都是0,另外注意该行代码可有可无,因为一个矩阵默认的初始态就是0

a(1:2:end,1:2:end) = 1;%先由奇数行入手,从第一列开始依次把1放置在需要的位置

a(2:2:end,2:2:end) = 1;%接着由偶数行入手,从第二列开始依次把1放置在需要的位置上

end1

2

3

4

5

文章来源: blog.csdn.net,作者:lyang1998,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/lyang1998/article/details/112673352

Logo

汇聚全球AI编程工具,助力开发者即刻编程。

更多推荐