【秋招笔试】24-07-31-影石insta-秋招笔试题
🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员
💻 ACM金牌团队🏅️ | 多次AK大厂笔试 | 编程一对一辅导
✨ 本系列打算持续跟新
秋招笔试题
👏 感谢大家的订阅➕ 和 喜欢💗 和 手里的小花花🌸
✨ 笔试合集传送们 -> 🧷春秋招笔试合集
💻 第一题
题目描述
给定一个字符串矩阵,例如:
##......
..##....
....##..
......##
....##..
..##....
##......
实现函数 solution(矩阵)
,将矩阵顺时针旋转90°后返回。例如,上述矩阵旋转后的结果为:
#.....#
#.....#
.#...#.
..#.#..
..#.#..
.#...#.
#.....#
题解
要将矩阵顺时针旋转90度,可以按照以下步骤进行:将矩阵的每一列变成新的行,从最后一列开始,依次将每一列变成新的行。
参考代码
- Python
def solution(matrix):
n = len(matrix)
m = len(matrix[0])
rotated_matrix = ['' for _ in range(m)]
# 遍历每一列
for i in range(m):
# 遍历每一行
for j in range(n):
# 将当前列的元素添加到新行中
rotated_matrix[i] += matrix[n - 1 - j][i]
return rotated_matrix
- Java
import java.util.*;
public class Main {
public static List<String> solution(List<String> matrix) {
int n = matrix.size();
int m = matrix.get(0).length();
List<String> rotatedMatrix = new ArrayList<>();
// 遍历每一列
for (int i = 0; i < m; i++) {
StringBuilder newRow = new StringBuilder();
// 遍历每一行
for (int j = n - 1; j >= 0; j--) {
// 将当前列的元素添加到新行中
newRow.append(matrix.get(j).charAt(i));
}
rotatedMatrix.add(newRow.toString());
}
return rotatedMatrix;
}
}
- Cpp
#include <iostream>
#include <vector>
#include <string>
using namespace std;
vector<string> solution(const vector<string>& matrix) {
int n = matrix.size();
int m = matrix[0].size();
vector<string> rotatedMatrix(m, string(n, ' '));
剩余60%内容,订阅专栏后可继续查看/也可单篇购买
学长刷题笔记 文章被收录于专栏
这里收集了超全的刷题笔记,欢迎大家的订阅,会持续跟新的