2020--07--16 矩阵右螺旋

spiral-matrix-ii

https://www.nowcoder.com/practice/25ec7a8bf1954a449a13a901e382600d?tpId=46&&tqId=29120&rp=1&ru=/ta/leetcode&qru=/ta/leetcode/question-ranking

题目描述
给定一个整数n,将数字1到
n2n^2
n
2
按螺旋的顺序填入n×n的矩阵
例如:
给出的n=3,
你应该返回如下矩阵:

[↵ [ 1, 2, 3 ],↵ [ 8, 9, 4 ],↵ [ 7, 6, 5 ]↵]

找规律:图片说明
1、每次走最外层一个圈,一圈分四条线
2、比如说[0,0到3],[0到3,4],[4,4到1],[4到1,0]
3、用left和right可以表示上面的数组范围
4、函数里面循环一次走一圈,一共要走n/2 (+1)次

代码实现

public int circle(int[][] array,int left,int right,int n){
        if (left==right){array[left][right]=n++;return  n;}
        for(int i =left;i<=right-1;i++){
            array[left][i]=n++;
        }
        for(int j=left;j<=right-1;j++){
            array[j][right]=n++;
        }
        for(int i =right;i>=left+1;i--){
            array[right][i]=n++;
        }
        for(int i =right;i>=left+1;i--){
            array[i][left]=n++;
        }
        return n;
    }
    public int[][] generateMatrix (int n) {
        // write code here
        int[][] array = new int[n][n];
        int left = 0;
        int right = n-1;
        int key = 1;
        while (left*right<=n*n) {
            key = circle(array,left++,right--,key);
        }
        return array;
    }
全部评论

相关推荐

秋招进行到现在终于能写总结了。完全没想到战线会拉这么长,过程会如此狼狈,不过更应该怪自己太菜了。好在所有的运气都用在了最后,也是有个去处。背景:双2本硕科班,无竞赛,本科一段研究所实习,硕士一段大厂暑期实习但无转正。技术栈是C++&nbsp;&amp;&nbsp;Golang,实习是客户端音视频(而且是鸿蒙端开发),简历两个C++项目一个Golang项目。主要投递岗位:后端,cpp软开,游戏服务端,测开,以及一些不拘泥于Java的岗位。从8月起总共投递123家公司,笔试数不清了,约面大约30家。offer/oc/意向:友塔游戏(第一个offer,面试体验很好,就是给钱好少南瑞继保(计算机科班点击就送(限男生),不...
乡土丁真真:佬很厉害,羡慕~虽然我还没有到校招的时候,也想讲一下自己的看法:我觉得不是CPP的问题,佬的背书双2,技术栈加了GO,有两段实习。投了123,面了30.拿到11个offer。这个数据已经很耀眼了。这不也是CPP带来的吗?当然也不止是CPP。至少来说在这个方向努力过的也会有好的结果和选择。同等学历和项目选java就会有更好的吗?我个人持疑问态度。当然CPP在方向选择上确实让人头大,但是我觉得能上岸,至于最后做什么方向,在我看来并不重要。至于CPP特殊,有岗位方向的随机性,java不是不挑方向,只是没得选而已。也希望自己以后校招的时候能offer满满
点赞 评论 收藏
分享
耀孝女:就是你排序挂了
点赞 评论 收藏
分享
评论
4
1
分享
牛客网
牛客企业服务