2025 图形(蓝桥杯十六届C组程序题 C 题)

样例输入:

4 5

样例输出:

20252

02520

25202

52025

代码如下:

#include <stdio.h>
#include <string.h>

void draw2025(int i,int w)
{
const char base\[\] = "2025";
int baselen = strlen(base);
for(int j = 0;j < w;j++)
{
printf("%c",base(i+j) % baselen);
}
printf("\n");
}

int main()
{
int h,w;
scanf("%d %d",&h,&w);
for(int i=0;i < h;i++)
{
draw2025(i,w);
}
return 0;
}

🏭 核心部件:draw2025 函数(印刷机器)

这个函数的任务很简单:只负责打印一行,然后换行

参数含义
i:代表行号。机器需要知道现在是第几行,才能决定从 "2025" 的哪个字开始印(实现错位效果)。
w:代表宽度。这一行要印多少个字符。
核心算法 (i + j) % baselen
这是整段代码的灵魂,用来解决**"循环"** 和**"错位"**两个问题。
base 是 "2025",长度 baselen 是 4。
i 是行号,j 是列号。
取模运算(%) :就像钟表一样,数到 4 就回到 0。
复制代码
##### 当 `i=0`(第1行):索引是 0,1,2,3,0,1...0,1,2,3,0,1... → 输出 **202520...**
复制代码
##### 当 `i=1`(第2行):索引是 1,2,3,0,1,2...1,2,3,0,1,2... → 输出 **025202...**(自动实现了向左移动一位的效果!)

👷 主控中心:main 函数(车间主任)

流程解析
接收输入:比如输入 5 10(高5,宽10)。
循环调用
复制代码
 ##### 第一次循环(i=0):调用 `draw2025(0, 10)` → 机器打印第 1 行。
复制代码
 ##### 第二次循环(i=1):调用 `draw2025(1, 10)` → 机器打印第 2 行(自动错位)。
复制代码
 ##### ...以此类推,直到打印完第 5 行。

📊 举例演示

假设输入 h=2, w=5

  1. 第 1 轮循环**(i=0)**:

    • 调用 draw2025(0, 5)
    • 内部循环 j 从 0 到 4。
    • 索引计算: (0 + 0) % 4 = 0(0 + 0) % 4 = 0 ( '2' ), (0 + 1) % 4 = 1(0 + 1) % 4 = 1 ( '0' )...
    • 输出:20252,然后换行。
  2. 第 2 轮循环**(i=1)**:

    • 调用 draw2025(1, 5)
    • 内部循环 j 从 0 到 4。
    • 索引计算: (1 + 0) % 4 = 1(1 + 0) % 4 = 1 ( '0' ), (1 + 1) % 4 = 2 (1 + 1) % 4 = 2 ('2')...
    • 输出:02520,然后换行。
相关推荐
先吃饱再说12 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰14 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术16 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六19 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术20 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize20 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队2 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法