斜对角线"之字形"打印矩阵

要求返回一个m x n的vector<vector<int>>数组,数组中的元素为0至m x n -1,要求沿着斜线排列,如下所示
[0     1      5      6 ]
[2     4      7      10]
[3     8      9      11]

class Solution {
public:
    vector<vector<int> > print_rectangle(int m,int n) {

    	vector<vector<int>> ret(m,vector<int>(n));
    	int val = 0;
    	int i = 0;
    	int j = 0;
    	int flag = 0;
    	while(0<=i && i<m && 0<=j && j<n)
    	{
    		if(flag == 0)
    		{
    			while(0<=i && j<n)
    			{
    				ret[i][j] = val;
    				val++;
    				i--;
    				j++;
    			}
    			i--;
    			j++;
    			(j == n-1)?i++:j++;
    		}
    		else
    		{
    			while(i<m && 0<=j)
    			{
    				ret[i][j] = val;
    				val++;
    				i++;
    				j--;

    			}
    			i++;
    			j--;
    			(i == m-1)?j++:i++;
    		}
    		flag = 1-flag;
    	}
    	return ret;
    }
};

  

原文地址:https://www.cnblogs.com/zjuhaohaoxuexi/p/11829127.html

时间: 2024-10-05 05:04:44

斜对角线"之字形"打印矩阵的相关文章

《程序员代码面试指南》第八章 数组和矩阵问题 &quot;之&quot;字形打印矩阵

题目 "之"字形打印矩阵 java代码 package com.lizhouwei.chapter8; /** * @Description: "之"字形打印矩阵 * @Author: lizhouwei * @CreateDate: 2018/4/28 22:53 * @Modify by: * @ModifyDate: */ public class Chapter8_3 { public void printMatrixZigZag(int[][] matri

[算法]“之”字形打印矩阵

题目: 给定一个矩阵matrix,按照“之”字形的方式打印这个矩阵.例如: 1   2   3   4 5   6   7   8 9  10  11 12 “之”字形打印的结果为:1,2,5,9,6,3,4,7,10,11,8,12 要求额外的空间复杂度为O(1). 思路: 1.上坐标(tR,tC)的初始为(0,0),先沿着矩阵的第一行移动(tC++),当达到第一行最右边的元素后,再沿着矩阵最后一列移动  (tR++). 2.下坐标(dR,dC)的初始为(0,0),先沿着矩阵的第一列移动(dR

之字形打印矩阵

题目描述 对于一个矩阵,请设计一个算法,将元素按“之”字形打印.具体见样例. 给定一个整数矩阵mat,以及他的维数nxm,请返回一个数组,其中元素依次为打印的数字. 测试样例: [[1,2,3],[4,5,6],[7,8,9],[10,11,12]],4,3 返回:[1,2,3,6,5,4,7,8,9,12,11,10] Solution 1: class Printer { public: vector<int> printMatrix(vector<vector<int>

矩阵--“之”字形打印矩阵

给定一个矩阵matrix, 按照"之" 字形的方式打印这个矩阵, 例如: 1 2 3 4 5 6 7 8 9 10 11 12"之" 字形打印的结果为: 1, 2, 5, 9, 6, 3, 4, 7, 10, 11,8, 12[要求] 额外空间复杂度为O(1). 原文地址:https://www.cnblogs.com/SkyeAngel/p/8745955.html

算法初级面试题03——队列实现栈、栈实现队列、转圈打印矩阵、旋转矩阵、反转链表、之字打印矩阵、排序矩阵中找数

第一部分主要讨论:栈.队列.数组矩阵相关的面试题 题目一 用数组结构实现大小固定的队列和栈 public static class ArrayStack { private Integer[] arr; private Integer size; public ArrayStack(int initSize) { if (initSize < 0) { throw new IllegalArgumentException("The init size is less than 0"

如何打印矩阵

如何打印矩阵 顺时针方向打印矩阵 如何顺时针打印一个矩阵的元素呢,例如:如果输入如下矩阵: 1              2              3              45              6              7              89              10           11           1213           14           15           16 则依次打印出数字:1, 2, 3, 4, 8, 12,

顺时针打印矩阵

P128顺时针打印矩阵 题目:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字.例如:如果输入如下矩阵: 1  2  3  4 5  6  7  8 9  10 11 12 13 14 15 16 则依次打印出数字:1.2.3.4.8.12.16.15.14.13.9.5.6.7.11.10 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h>   #include<stdlib.h>   void printMatri

蛇形数组和“之”字形打印

蛇形数组: 上面的数组就叫做蛇形数组. 如何打印蛇形数组:一定不要一行一行的考虑,不然就陷入误区了. #include<stdio.h> #include<stdlib.h> #define line 10  void initsarr(int arr[line][line]) { int i1 = 0; int j1 = 0; int m1 = line - 1; int n1 = line - 1; int k = 0; int i2; int j2; int m2; int 

顺时针打印矩阵-剑指Offer

顺时针打印矩阵 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10. 思路 整体是按着一圈一圈打印,需要找到循环继续的条件:columns > startX * 2并且rows > startY * 2 注意打印每圈的时候,四个边的打印循环起始条件 代码 import java.