旋转数字矩阵 od

结构得记一下,否则还是刷不出来。参考leetcode 螺旋矩阵2 No59 代码随想录版本。

区别的地方在于:

1、里面的列数自己决定,需要判断最小列

2、数量小于行数,单独打印输出。

3、其他情况1:要考虑 count已经写完,单矩阵有空余,需要输出'*'

4、其他情况2:count需要在两个地方控制,一个是while(负责大圈停止的)一个是for循环(count<= size防止数超了)

复制代码
#include <iostream>
#include "vector"
using namespace std;

void print(int size, int row) {
    int a = 0; 
    for (int i = 1; i < size + 1; i++) {
        cout<<i<<endl;
    }
    int count = row - size;
    while(count--) {
        cout<<'*'<<endl;
    }
    return;
}

int main() {
    int size,row, col;
    while (cin >> size >> row) { // 注意 while 处理多个 case
        if (size <= row) {
            print(size,row); // 如果一列就能放下就放下
            return 0;
        } else {
            col = size / row + 1;//用最少得列数,用总数量/行数 +1 即列数。
        }
        vector<vector<int>> vec(row,vector<int>(col));

        int start_x = 0;
        int start_y = 0;
        int offset = 1;
        int count = 1;
        int i,j;

        while(count <= size) {
            i = start_x;
            j = start_y;
            //向右
            for (j = start_y; j < col - offset && count <= size; j++) {
                vec[i][j] = count++;
            }
            //向下
            for (i = start_x; i < row - offset && count <= size; i++) {
                vec[i][j] = count++;
            }
            //向左
            for (; j > start_y && count <= size; j--) {
                vec[i][j] = count++;
            }
            //向上
            for (; i > start_x && count <= size; i--) {
                vec[i][j] = count++;
            }

            start_x++;
            start_y++;
            offset+=1;
        }

        for(int i = 0; i < vec.size(); i++) {
            for (int j = 0; j < vec[i].size(); j++) {
                if (vec[i][j] == 0) {
                    cout<<'*'<<' ';
                } else {
                    cout<<vec[i][j]<<' ';
                }
            }
            cout<<endl;
        }
       
    }
     return 0;
    
}
// 64 位输出请用 printf("%lld")
相关推荐
hh随便起个名1 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
Dingdangcat863 小时前
城市交通多目标检测系统:YOLO11-MAN-FasterCGLU算法优化与实战应用_3
算法·目标检测·目标跟踪
tang&3 小时前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
拼命鼠鼠3 小时前
【算法】矩阵链乘法的动态规划算法
算法·矩阵·动态规划
LYFlied4 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展
式5164 小时前
线性代数(八)非齐次方程组的解的结构
线性代数·算法·机器学习
橘颂TA5 小时前
【剑斩OFFER】算法的暴力美学——翻转对
算法·排序算法·结构与算法
叠叠乐5 小时前
robot_state_publisher 参数
java·前端·算法
hweiyu005 小时前
排序算法:冒泡排序
算法·排序算法
brave and determined5 小时前
CANN训练营 学习(day9)昇腾AscendC算子开发实战:从零到性能冠军
人工智能·算法·机器学习·ai·开发环境·算子开发·昇腾ai