【GESP】C++二级真题 luogu-b3955, [GESP202403 二级] 小杨的日字矩阵
GESP二级真题,多层循环、分支语句练习,难度★✮☆☆☆。
luogu-B3955 [GESP202403 二级] 小杨的日字矩阵
题目要求
题目描述
小杨想要构造一个 $N\times N$ 的日字矩阵($N$ 为奇数),具体来说,这个矩阵共有 $N$ 行,每行 $N$ 个字符,其中最左列、最右列都是
|
,而第一行、最后一行、以及中间一行(即第 $\frac{N+1}{2}$ 行)的第 $2\sim N-1$ 个字符都是-
,其余所有字符都是半角小写字母x
。例如,一个 $N = 5$ 日字矩阵如下:
1 2 3 4 5|---| |xxx| |---| |xxx| |---|
请你帮小杨根据给定的 $N$ 打印出对应的“日字矩阵”。
输入格式
一行一个整数 $N$($5\leq N \leq 49$,保证 $N$ 为奇数)。
输出格式
输出对应的“日字矩阵”。
请严格按格式要求输出,不要擅自添加任何空格、标点、空格等任何符号。你一个恰好输出 $N$ 行,每行除了换行符外恰好包含 $N$ 个字符,这些字符要么是
-
,要么是|
,要么是x
。你的输出必须和标准答案完全一致才能得分,请在提交前仔细检查。
样例输入 #1
1
5
样例输出 #1
1
2
3
4
5
|---|
|xxx|
|---|
|xxx|
|---|
样例输入 #2
1
7
样例输出 #2
1
2
3
4
5
6
7
|-----|
|xxxxx|
|xxxxx|
|-----|
|xxxxx|
|xxxxx|
|-----|
题目分析
解题思路
- 首先,读取输入的整数
N
,并确保它在指定的范围内($5\le N \le 49$)且为奇数。 - 初始化一个循环变量
i
,用于控制输出的行数。 - 使用一个循环来输出“日字矩阵”,从
1
到N
。 - 在每次循环中,首先输出一个竖线
|
,然后根据行数i
的位置输出相应的字符:- 如果
i
等于(N + 1) / 2
,输出-
,形成矩阵的中间横线。 - 否则,输出
x
,形成矩阵的上下边界和内部。
- 如果
- 每行输出完成后,输出一个竖线
|
,并换行。 - 循环结束后,输出完成。
示例代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
using namespace std;
int main() {
int n; // 定义整数变量n,用于存储矩阵的大小
cin >> n; // 从输入流读取整数到n
for (int i = 1; i <= n; i++) { // 从1到n进行循环,模拟每一行的输出
cout << "|"; // 输出竖线,表示矩阵的边界
for (int j = 1; j <= n - 2; j++) { // 从1到n-2进行循环,模拟每一行中间部分的输出
if (i == 1 || i == n || i == (n + 1) / 2) { // 判断当前行是否是第一行、最后一行或中间行
cout << "-"; // 如果是,则输出横线,形成矩阵的中间横线
} else {
cout << "x"; // 否则,输出小写字母x,形成矩阵的上下边界和内部
}
}
cout << "|" << endl; // 输出竖线,表示矩阵的边界,并换行
}
}
所有代码已上传至Github:https://github.com/lihongzheshuai/yummy-code
GESP各级别考纲要点、知识拓展和练习题目清单详见C++学习项目主页
“luogu-”系列题目已加入洛谷Java、C++初学团队,作业清单,可在线评测,团队名额有限,欢迎加入。
“bcqm-”系列题目可在编程启蒙题库进行在线评测。
本文由作者按照 CC BY 4.0 进行授权