llllmz

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

59. 螺旋矩阵 II

不知道一年后会成长成什么样,只感觉好难好难。有好多东西要学,源码也看不懂,项目也不会做。

class Solution {
public:
vector<vector<int>> generateMatrix(int n) {
vector<vector<int>> vec(n, vector<int>(n, 0));
int num = 1;
for(int i = 0; i < n; ++i){
if(vec[i][i] == 0) insert(i, num, n, vec);
}
return vec;
}
void insert(int curPosition, int& num, int n, vector<vector<int>>& vec){
int i = curPosition, j = curPosition;// i是行,j是列
for(;j < n; ++j){//向右
if(vec[i][j] == 0){
vec[i][j] = num++;
}else{
break;
}
}
++i;
--j;
for(;i < n; ++i){//向下
if(vec[i][j] == 0){
vec[i][j] = num++;
}else{
break;
}
}
--j;
--i;
for(;j >= 0; --j){//向左
if(vec[i][j] == 0){
vec[i][j] = num++;
}else{
break;
}
}
--i;
++j;
for(;i >= 0; --i){//向上
if(vec[i][j] == 0){
vec[i][j] = num++;
}else{
break;
}
}
}
};

 

posted on   神奇的萝卜丝  阅读(5)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示