剑指offer-面试题29-顺时针打印矩阵-矩阵
/*
题目:
输入一个矩阵,按照从外到内顺时针的顺序依次打印每一个数字。
*/
/*
思路:
1、将打印矩阵看作是打印一个个从外向内的环。
2、每一个环都有一个起始节点,起始节点的坐标*2小于行数和列数。
3、对于每一个环,分别打印从左到右,从上到下,从右到左,从下到上的数字。
*/
#include<iostream>
#include<string.h>
#include<algorithm>
#include<cmath>
#include<stdio.h>
#include<vector> using namespace std;
//res传引用
void printMatrixs(vector<vector<int> > mat,int rows,int columns,int start,vector<int> &res){
int right = columns - start;
int down = rows -start; //从左到右打印一行
for(int i = start; i < right; i++){
res.push_back(mat[start][i]);
}
//从上到下打印一列
for(int i = start + 1; i < down; i++){
res.push_back(mat[i][right-1]);
}
//从右到左打印一行,不和从右到左打印的行重复
if(down - 1 != start){
for(int i = right - 2; i >= start; i--){
res.push_back(mat[down-1][i]);
}
} //从下到上打印一列,不和从上到下打印的列重复
if(start != right - 1){
for(int i = down - 2; i > start; i--){
res.push_back(mat[i][start]);
}
} } vector<int> clockwisePrint(vector<vector<int>> mat, int rows, int columns) {
if(rows == 0 || columns == 0) throw("invalid parameters");
int start = 0;
vector<int> res;
while(start*2 < rows && start*2 <columns){
printMatrixs(mat,rows,columns,start,res);
start++;
}
return res;
} int main(){
vector<vector<int>> mat = {{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16}};
vector<int> res = clockwisePrint(mat,4,4);
for(int i = 0; i < res.size(); i++){
cout<<res[i]<<" ";
}
}
剑指offer-面试题29-顺时针打印矩阵-矩阵的更多相关文章
- 剑指Offer:面试题20——顺时针打印矩阵(java实现)
		
题目描述: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数 字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1, ...
 - 剑指 offer面试题20 顺时针打印矩阵
		
[题目描述] 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1, ...
 - Leetcode - 剑指offer 面试题29:数组中出现次数超过一半的数字及其变形(腾讯2015秋招 编程题4)
		
剑指offer 面试题29:数组中出现次数超过一半的数字 提交网址: http://www.nowcoder.com/practice/e8a1b01a2df14cb2b228b30ee6a92163 ...
 - 剑指Offer - 九度1391 - 顺时针打印矩阵
		
剑指Offer - 九度1391 - 顺时针打印矩阵2013-11-24 04:55 题目描述: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 ...
 - 剑指offer面试题5 从头到尾打印链表(java)
		
注:(1)这里体现了java数据结构与C语言的不同之处 (2)栈的操作直接利用stack进行 package com.xsf.SordForOffer; import java.util.Stack; ...
 - 剑指offer面试题5 从头到尾打印链表(c)
 - 剑指offer十九之顺时针打印矩阵
		
一.题目 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2, ...
 - 剑指offer——面试题29:顺时针打印矩阵
		
#include"iostream" #include"stdio.h" using namespace std; void PrintMatrixInCirc ...
 - 剑指Offer面试题:11.打印1到最大的n位数
		
一.题目:打印1到最大的n位数 题目:输入数字n,按顺序打印出从1最大的n位十进制数.比如输入3,则打印出1.2.3一直到最大的3位数即999. 二.不同的解法 2.1 不假思索的解法 最容易想到的办 ...
 - 【剑指offer】题目20 顺时针打印矩阵
		
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出 ...
 
随机推荐
- EMC NW NMM to backup MS AG
			
To use EMC NW NMM to backup MS SQL always on database, that is a simple and safe way to protector da ...
 - 基于 HTML5 WebGL 的智慧楼宇可视化系统
			
前言 可视化的智慧楼宇在 21 世纪是有急迫需求的,中国被世界称为"基建狂魔",全球高层建筑数量位居首位,所以对于楼宇的监控是必不可少.智慧楼宇可视化系统更多突出的是管理方面的功能 ...
 - RocketMQ重试机制和消息幂等
			
一.重试机制 由于MQ经常处于复杂的分布式系统中,考虑网络波动,服务宕机,程序异常因素,很有可能出现消息发送或者消费失败的问题.因此,消息的重试就是所有MQ中间件必须考虑到的一个关键点.如果没有消息重 ...
 - JVM垃圾回收机制和常用算法
			
由于疫情的原因,所以目前一直在家远程办公,所以很多时间在刷面试题,发现2019大厂的面试虽然种类很多,但是总结了一下发现主要是这几点:算法和数据结构. JVM.集合.多线程.数据库这几点在面试的时候比 ...
 - 在.NET Core中使用MachineKey
			
在.NET Core中使用MachineKey 姐妹篇:<ASP.NET Cookie是怎么生成的> 姐妹篇:<.NET Core验证ASP.NET密码> 在上篇文章中,我介绍 ...
 - crul 命令访问公网 dns解析错误 程序报错
			
今天机房几台服务器都无法访问公网接口,原因是——解析公网域名出错,具体情况如下 ping 公网ip或者域名 都没有问题 curl 公网域名 出错 curl -4 访问公网域名没有问题 综合分析 ...
 - Django (一) 基础
			
创建项目 创建app python manager.py startapp app01 修改.添加url from django.conf.urls import url,include fr ...
 - AVR单片机教程——示波器
			
本文隶属于AVR单片机教程系列. 在用DAC做了一个稍大的项目之后,我们来拿ADC开开刀.在本讲中,我们将了解0.96寸OLED屏,移植著名的U8g2库到我们的开发板上,学习在屏幕上画直线的算法, ...
 - Arm开发板+Qt学习之路-论can网通讯受log日志的影响
			
日期:2016-05-25 最近开发过程中发现一个问题,使用两个开发板进行can网通讯,按照经验来说,通讯的速度应该是很快的,项目中将接口的超时时间设置为100ms,在某种情境下,会在短时间内发送多次 ...
 - codewars--js--RGB To Hex Conversion
			
问题描述: The rgb() method is incomplete. Complete the method so that passing in RGB decimal values will ...