2023 年 09 月 二级真题(1)--小杨的 X 字矩阵

【题目】

样例输入:

5

样例输出

【解题思路】

图形的输出一定采用双层循环,外层循环控制输出的行数,内层循环控制每一行输出的内容。

图形的输出难点是找每一行输出的某些符号的数量与行号的关系,有时候这种关系不能找到一个统一的公式,需要将图形拆分成几部分分别找规律再输出。

本题可以将图形分成上下两部分输出,上半部分和下半部分的输出是相反的的关系,所以在写完上半部分输出代码后,只需要将控制外层循环的i的取值反向获取即可。

上下对称的图形,中间一行往往要单独输出。

【代码】

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n;//输出n行
    cin>>n;
    //第一部分:输出上半部分
    for(int i=1;i<=n/2;i++)
    {
        for(int j=1;j<=i-1;j++)
            cout<<'-';
        cout<<'+';
        for(int j=1;j<=n-i*2;j++)
            cout<<'-';
        cout<<'+';
        for(int j=1;j<=i-1;j++)
            cout<<'-';
        cout<<endl;
    }
    //第二部分:输出中间一行
    for(int i=1;i<=(n-1)/2;i++)
        cout<<'-';
    cout<<'+';
    for(int i=1;i<=(n-1)/2;i++)
        cout<<'-';
    cout<<endl;
    //第二部分:输出下半部分
    for(int i=n/2;i>=1;i--)
    {
        for(int j=1;j<=i-1;j++)
            cout<<'-';
        cout<<'+';
        for(int j=1;j<=n-i*2;j++)
            cout<<'-';
        cout<<'+';
        for(int j=1;j<=i-1;j++)
            cout<<'-';
        cout<<endl;
    }
    return 0;
}

【划重点】

以上思路只是其中的一种解题思路,也欢迎大家留言说一下自己的解题思路。

相关推荐
铸人2 小时前
再论自然数全加和 - 欧拉伽马常数4
算法
prince_zxill2 小时前
探索Nautilus Trader:高性能算法交易平台与事件驱动回测引擎的全面指南
算法
进击的荆棘2 小时前
算法——二分查找
c++·算法·leetcode
识君啊2 小时前
Java 滑动窗口 - 附LeetCode经典题解
java·算法·leetcode·滑动窗口
烟花落o2 小时前
【数据结构系列02】轮转数组、返回倒数第k个节点
数据结构·算法·leetcode·刷题
努力也学不会java2 小时前
【Spring Cloud】统一服务入口-Gateway
后端·算法·spring·spring cloud·gateway·服务发现
追随者永远是胜利者2 小时前
(LeetCode-Hot100)3. 无重复字符的最长子串
java·算法·leetcode·职场和发展·go
Lenyiin2 小时前
《LeetCode 顺序刷题》11 -20
java·c++·python·算法·leetcode·lenyiin
乌萨奇也要立志学C++2 小时前
【洛谷】从记忆化搜索到动态规划 状态表示 + 转移方程 + 空间优化全攻略
算法·动态规划