news 2026/6/9 23:28:44

C语言中以坐标的方式图解“字母金字塔”的绘制

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言中以坐标的方式图解“字母金字塔”的绘制

目录

  • 题目
  • 题目解析
    • 题目理解
    • 空格图-坐标解析
    • 字母递增图-坐标解析
    • 字母递减图-坐标解析
  • 代码汇总验证
    • 代码汇总
    • 终端运行验证
  • 坐标图解法的好处
    • 建议
    • 好处

题目

实现字母金字塔,通过键盘输入字符来控制层数,如输入D,则打印下面图形

A ABA ABCBA ABCDCBA

题目解析

题目理解

由题目中的图形可知,主要是打印字母的金字塔,这个金字塔怎么构成的勒:

  • 每一行都是以首字母A开始,递增后到每一行的最大值后,又递减到首字母A结束;
  • 行数等于输入字母-首字母数即:char(D)-A+1;
  • 每一行最中间的字母以此增加,到输入字母char(D)结束;
  • 每一行的最大值跟行数成现行关系:A+i+x(系数);
  • 假如不是最后一行,那么在输入字母之前需要先有空格;
  • 每一行的字母数量是行数*2-1个;

如果把这个字母金字塔看成一个整体,那么我们不但需要判断打印空格的时机,还要判断打印递增字母的时机,还得判断递减字母的时机,会导致思路很复杂。这种复杂的想法不适合初学者思考,因此我这边建议将图形分开成三份后再做处理

假定:

  • 1)输入的变量元素(chr)就是D,首元素就是A;
  • 2)那么需要打印的行数就是len= D-A+1=4;
  • 3)i代表行数,j代表列数;

空格图-坐标解析

i/j0123
0***
1**
2*
3

空格坐标图(以*表示占位)

根据空格图我们知道需要打印的空格以代码表示为:

for(inti=0;i<=len-1;i++){//从坐标图看从i=0开始就有,到3结束,共4列,也就等于len-1=4-1=3for(intj=0;j<len-1-i;j++){//从坐标图看从j=0开始,第一行打印到len-1-1结算,之后以此少打一个,即到j=(len-1)-i结束;printf(" ");//打印空格;}printf("\n");//一行打印完后进行换行}

字母递增图-坐标解析

i/j0123
0A
1AB
2ABC
3ABCD

字母递增图

空格已经打印完了的情况下,即空格已经占位好了,那么这个字母递增图从实际写代码出发会进行变种到如下所示:

i/j0123
0A
1AB
2ABC
3ABCD

字母递增图修订

根据坐标图我们知道需要打印递增字母以代码表示为:

for(inti=0;i<=len-1;i++){//从坐标图看从i=0开始就有,到3结束,共4列,也就等于len-1=4-1=3for(intj=0;j<=i;j++){//从坐标图看从j=0开始,每一行都是i=j的时候结束;printf('A'+j);//打印字母,以首字母A开始,每一列加j;}printf("\n");//一行打印完后进行换行}

字母递减图-坐标解析

i/j0123
0
1A
2BA
3CBA

字母递减坐标图

根据坐标图我们知道需要打印的代码表示为:

for(inti=0;i<=len-1;i++){//从坐标图看从i=0开始就有,到3结束,共4列,也就等于len-1=4-1=3for(intj=1;j<=i;j++){//从坐标图看从j=1开始,每一行都是i=j的时候结束;printf('A'+i-j);//打印字母,每次结束的时候都是A,然后以此往坐标的左边加1,所以是-j,每一行又都是i=j时结束,所以加了一个i,带入公式验证两行无误即可编译验证;}printf("\n");//一行打印完后进行换行}

代码汇总验证

代码汇总

intmain(intargc,charconst*argv[]){charchr;printf("input char A~Z/a~z/0-9:");scanf("%c",&chr);charchr_sop;intlen;switch(chr){case'A'...'Z':len=chr-'A'+1;chr_sop='A';break;case'a'...'z':len=chr-'a'+1;chr_sop='a';break;case'0'...'9':len=chr-'0'+1;chr_sop='0';break;default:printf("input error\n");return0;break;}for(chari=0;i<=len-1;i++){for(intj=0;j<(len-1)-i;j++){printf(" ");}for(intj=0;j<=i;j++){printf("%c",chr_sop+j);}for(intj=1;j<=i;j++){printf("%c",chr_sop+i-j);}printf("\n");}return0;}

我这里汇总的代码与前面的图解代码几乎一模一样。
只是做了以下优化
:

  • 1)将字符的长度与首字符用变量len和chr_sop表示,方便处理不同的类型;
  • 2)用switch …case…语句将输入的字符分类,扩展到可以处理三种类型的金字塔;
  • 3)在字符完全不合规的情况下,直接return 退出执行代码;
  • 其余地方与图解一样,甚至连坐标的起始都一样。

终端运行验证

可以看到输出的结果与题目一模一样,且可以打印超过D大小的金字塔;

坐标图解法的好处

建议

  • 1)初学者做图形打印练习的时候都先画坐标图,再写代码;
  • 2)初学者的坐标都以i/j都以0(或1)开始,自加形式,然后去找结束条件;

好处

可以从坐标图清晰看出:

  • 图形的i有几列,第一层循环很清晰,****基本可以无脑写(int i=0;i<=x;i++)
  • 每一行的打印开始位置,且都是自增的情况下,第二层循环可以无脑先写成(for(int j=0(或则其他,根据图来);循环条件;j++))。然后就再去找循环的条件即可;
  • 可以很清晰的看出来每行的打印规律,而且就算第一次没把规律找对,也可以很对照坐标很轻松验证,再去调整;

总结一下好处就是:

  • 1)循环体很好写出来:
    • 不用纠结循环体的写法;
    • 只要去找循环条件即可;
    • 都是自增,不用多余考虑是否需要自减;
  • 2)对比思路很清晰顺带梳理了写代码的思路
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 14:21:18

Q CLI 助力合合信息实现 Aurora 的升级运营

1. 升级背景 合合信息是一家中国领先的人工智能(AI)产品公司&#xff0c;一直致力于通过AI技术赋能创新&#xff0c;为全球数亿用户和多元化行业提供产品服务。凭借超过18年的AI研究和应用专业知识&#xff0c;合合信息已成为全球多模态大模型文本智能技术的领先者&#xff0c…

作者头像 李华
网站建设 2026/6/8 8:06:06

PDF对比终极指南:三步快速定位文档差异

PDF对比终极指南&#xff1a;三步快速定位文档差异 【免费下载链接】diff-pdf A simple tool for visually comparing two PDF files 项目地址: https://gitcode.com/gh_mirrors/di/diff-pdf 在文档处理工作中&#xff0c;PDF对比是每个职场人士都会遇到的常见需求。无论…

作者头像 李华
网站建设 2026/6/9 23:26:31

OBS Studio直播画质提升实战指南:7个立竿见影的设置技巧

OBS Studio直播画质提升实战指南&#xff1a;7个立竿见影的设置技巧 【免费下载链接】obs-studio 项目地址: https://gitcode.com/gh_mirrors/obs/obs-studio 想要实现专业级的直播画质&#xff0c;OBS Studio直播优化和推流质量提升是每个主播必须掌握的技能。无论是直…

作者头像 李华
网站建设 2026/6/9 15:03:52

PostgreSQL vs MySQL:工程视角下的数据库选型终极指南

PostgreSQL vs MySQL 数据库选型终极指南(生产级实战版) 数据库选型不是功能清单的比拼,而是对业务复杂度、团队能力与未来不确定性的判断。 在实际项目中,“到底选 PostgreSQL 还是 MySQL”几乎是每个技术团队都会遇到的经典问题。它表面看是数据库对比,实质上是工程哲学…

作者头像 李华
网站建设 2026/6/8 20:29:47

构建AI知识库助手:LobeChat与RAG技术集成方案

构建AI知识库助手&#xff1a;LobeChat与RAG技术集成方案 在企业数字化转型加速的今天&#xff0c;员工每天面对海量文档、政策手册和内部知识库&#xff0c;却常常“知道信息存在&#xff0c;但找不到答案”。传统搜索引擎返回的是链接列表&#xff0c;而通用大模型如ChatGPT虽…

作者头像 李华