【C++】1006 - 打印星号三角形 1007 - 统计大写英文字母的个数 1008 - 字符图形9-数字正三角

文章目录

  • 问题一:1006 - 打印星号三角形
    • 题目描述:
    • 输入:
    • 输出:
    • 样例:
    • 1.分析问题
    • 2.定义变量
    • 3.输入数据
    • 4.数据计算
    • 5.输出结果
  • 问题二:1007 - 统计大写英文字母的个数
    • 题目描述:
    • 输入:
    • 输出:
    • 样例:
    • 1.分析问题
    • 2.定义变量
    • 3.输入数据
    • 4.数据计算
    • 5.输出结果
  • 问题三:1008 - 字符图形9-数字正三角
    • 题目描述:
    • 输入:
    • 输出:
    • 样例:
    • 1.分析问题
    • 2.定义变量
    • 3.输入数据
    • 4.数据计算
    • 5.输出结果
  • 总结
  • 感谢


问题一:1006 - 打印星号三角形

类型:嵌套循环


题目描述:

打印星号三角形。

输入:

输入只有一行,包括1个整数N,N代表行数;

输出:

输出N行;

样例:

输入:

5

输出:

    *        *        ****      ***      ********    *****    ************  *******  *******
***************************

在这里插入图片描述


1.分析问题

  1. 已知:1个整数N。
  2. 未知:打印出符合条件的图形。

2.定义变量

  • 定义变量int n并从标准输入读取用户输入的整数,这个整数n将决定要打印的三角形的行数。
    int n;

3.输入数据

  • 从标准输入读取用户输入的整数n。
    cin>>n;

4.数据计算

  • 外层循环(控制行数):变量i从1遍历到n,代表当前正在处理的行。

  • 中层循环(控制每行的三个部分:左侧空格、星号和右侧空格):变量j从1遍历到3,确保每行打印完左侧空格、星号和右侧空格这三个子串。

  • 左侧空格打印:内层循环(变量k)根据当前行数i打印相应的空格数量,使得星号部分能向右移动形成三角形形状。

  • 星号打印:再次使用内层循环(变量k),打印2倍当前行数减1个星号,形成等腰三角形的主体部分。

  • 右侧空格打印:与左侧空格打印相同,根据当前行数i打印相应数量的空格,保持图形左右对称。

  • 每打印完一行后,使用cout<<endl;进行换行,准备打印下一行。

// 外层循环控制打印行数,范围为1到nfor(int i=1; i<=n; i++){// 中层循环控制每行打印3个子串(空格、星号、空格)for(int j=1; j<=3; j++){// 左侧空格打印,循环次数由当前行数i决定for(int k=1; k<=n-i; k++){cout<<" ";}// 星号打印,循环次数由2倍当前行数减1决定for(int k=1; k<=2*i-1; k++){cout<<"*";}// 右侧空格打印,循环次数与左侧相同,保持图形对称for(int k=1; k<=n-i; k++){cout<<" "; }}// 每完成一行的打印后换行cout<<endl;}

5.输出结果

  • 主函数执行完毕后,默认返回0。整个程序运行后会在控制台显示出由星号构成的上三角形图案。
    // 主函数默认返回0return 0;

完整代码如下:

// 引入iostream库,用于实现输入输出功能
#include<iostream>
// 使用标准命名空间std,简化cout和cin的使用
using namespace std;// 主函数int main()
int main(){// 定义变量n,用于存储用户输入的整数int n;// 从标准输入读取用户输入的整数ncin>>n;// 外层循环控制打印行数,范围为1到nfor(int i=1; i<=n; i++){// 中层循环控制每行打印3个子串(空格、星号、空格)for(int j=1; j<=3; j++){// 左侧空格打印,循环次数由当前行数i决定for(int k=1; k<=n-i; k++){cout<<" ";}// 星号打印,循环次数由2倍当前行数减1决定for(int k=1; k<=2*i-1; k++){cout<<"*";}// 右侧空格打印,循环次数与左侧相同,保持图形对称for(int k=1; k<=n-i; k++){cout<<" "; }}// 每完成一行的打印后换行cout<<endl;}// 主函数默认返回0return 0;
}

问题二:1007 - 统计大写英文字母的个数

类型:字符串


题目描述:

算算以 ‘.’ 结束的一串字符中含有多少个大写的英文字母。

输入:

输入一串字符(长度不超过 80 ),以 ‘.’ 结束。

输出:

输出一行,即这串字符中大写字母的个数。

样例:

输入:

PRC,PRC,I'm from China.

输出:

8

在这里插入图片描述


1.分析问题

  1. 已知:一串字符。
  2. 未知:有多少个大写的英文字母。

2.定义变量

    int sum = 0; // 初始化字符计数器sum为0,用于计算大写字母的数量string input; // 定义一个字符串变量input,用于存储用户的输入

3.输入数据

  • 使用getline(cin, input);接收一行用户输入,这行输入可以包含任何字符(包括空格和标点符号)。
    // 使用getline读取一行用户输入(包括空格和标点符号)getline(cin, input);

4.数据计算

遍历输入的字符串input中的每个字符,使用for循环并以字符串长度作为上限。在遍历过程中:

  • 当遇到字符’.‘时,跳出循环,这意味着只统计’.'之前的大写字母数量。
  • 如果当前字符是空格或逗号,则跳过本次循环继续处理下一个字符(不计入大写字母计数)。
  • 检查当前字符是否为大写字母(ASCII值在’A’到’Z’之间),如果是,则将sum加1,表示已找到一个大写字母。
// 遍历输入字符串中的每个字符for (int i = 0; i <= input.length(); i++) {// 当遇到第一个'.'时跳出循环if (input[i] == '.') {break;}// 若当前字符是空格或逗号,则跳过本次循环继续处理下一个字符if (input[i] == ' ' || input[i] == ',') {continue;}// 检查当前字符是否在大写字母A到Z的范围内if (input[i] >= 'A' && input[i] <= 'Z') {sum++; // 如果是大写字母,则增加计数器sum的值}}

5.输出结果

  • 循环结束后,输出统计得到的大写字母数量。

  • 主函数返回0,表示程序执行成功结束。

	// 输出统计得到的大写字母数量cout << sum << endl;// 主函数执行完毕后返回0return 0;

完整代码如下:

#include<iostream>
#include<string> // 引入string库,以便处理字符串输入和输出
using namespace std; // 使用标准命名空间以简化cout, cin等操作int main() {int sum = 0; // 初始化字符计数器sum为0,用于计算大写字母的数量string input; // 定义一个字符串变量input,用于存储用户的输入// 使用getline读取一行用户输入(包括空格和标点符号)getline(cin, input);// 遍历输入字符串中的每个字符for (int i = 0; i <= input.length(); i++) {// 当遇到第一个'.'时跳出循环if (input[i] == '.') {break;}// 若当前字符是空格或逗号,则跳过本次循环继续处理下一个字符if (input[i] == ' ' || input[i] == ',') {continue;}// 检查当前字符是否在大写字母A到Z的范围内if (input[i] >= 'A' && input[i] <= 'Z') {sum++; // 如果是大写字母,则增加计数器sum的值}}// 输出统计得到的大写字母数量cout << sum << endl;// 主函数执行完毕后返回0return 0;
}

问题三:1008 - 字符图形9-数字正三角

类型:嵌套循环。


题目描述:

输入一个整数打印字符图形。

输入:

一个整数(0<N<10)。

输出:

一个字符图形。

样例:

输入:

3

输出:

  1222
33333

1.分析问题

  1. 已知:一个整数n。
  2. 待解决问题:打印出符合条件的字符图形。

2.定义变量

  • 定义变量n。
    int n;

3.输入数据

  • 从标准输入读取用户输入的整数。
    cin>>n;

4.数据计算

  • 外层循环(控制行数):变量i从1开始遍历到用户输入的n值,对应于要打印的每一行。

  • 第一层内循环(打印左侧空格):变量j从1开始遍历到n-i,确保每行的数字部分能逐行向右移动,形成三角形形状,通过打印空格实现此目的。

  • 第二层内循环(打印数字):变量k从1开始遍历到2*i-1,打印当前行数i的值,形成等腰三角形主体,即每行数字的数量等于当前行数的两倍减一。

  • 第三层内循环(打印右侧空格):与第一层内循环类似,变量l也从1开始遍历到n-i,打印空格以保持图形对称。

  • 每完成一行的打印后,使用cout<<endl;进行换行,准备打印下一行。

/ 外层循环控制打印行数(1到n)for(int i=1; i<=n; i++){// 内层循环1:打印左侧空格,循环次数由当前行数i决定,使得星号或数字逐行向右移动for(int j=1; j<=n-i; j++){cout<<" ";}// 内层循环2:打印当前行的数字i,循环次数由2倍当前行数减1决定,形成等腰三角形形状for(int k=1; k<=2*i-1; k++){cout<<i; // 注意此处是打印数字i而非星号*}// 内层循环3:打印右侧空格,循环次数与左侧相同,保持图形对称for(int l=1; l<=n-i; l++){cout<<' '; }// 每打印完一行后换行cout<<endl;}

5.输出结果

  • 主函数执行完毕后返回0,表示程序正常结束。
    // 主函数返回0return 0;

完整代码如下:

// 引入iostream库,提供cout和cin功能
#include<iostream>
// 使用标准命名空间std
using namespace std;// 定义主函数int main()
int main(){// 定义变量n并从标准输入读取用户输入的整数int n;cin>>n;// 外层循环控制打印行数(1到n)for(int i=1; i<=n; i++){// 内层循环1:打印左侧空格,循环次数由当前行数i决定,使得星号或数字逐行向右移动for(int j=1; j<=n-i; j++){cout<<" ";}// 内层循环2:打印当前行的数字i,循环次数由2倍当前行数减1决定,形成等腰三角形形状for(int k=1; k<=2*i-1; k++){cout<<i; // 注意此处是打印数字i而非星号*}// 内层循环3:打印右侧空格,循环次数与左侧相同,保持图形对称for(int l=1; l<=n-i; l++){cout<<' '; }// 每打印完一行后换行cout<<endl;}// 主函数返回0return 0;
}

总结

1. 问题一:打印特定字符构成的上三角形图案

  • 对于此类题目,通用解法是采用嵌套循环结构。首先读取用户输入的整数n表示三角形的高度,外层循环控制行数(从1到n),内层循环用于在每行中打印字符和空格以形成图形。具体而言,左侧空格的数量随着行数增加而减少,字符数量则根据规律(例如星号或数字)逐行递增,右侧空格与左侧保持对称。通过合理调整循环内部的条件判断和输出内容,可以实现各种字符构成的不同形状的三角形。

2. 问题二:计算字符串中特定字符类型的数量

  • 在处理这类问题时,通常采用遍历字符串的方法。先接收用户输入的一段文本,然后使用for循环或者范围for循环遍历字符串中的每个字符。针对不同需求,设置相应的条件判断,如在此例中检查字符是否为空格、逗号或大写字母,并利用计数器记录符合条件的字符个数。这种方法适用于统计任何给定字符串中特定类型字符的数量。

3. 问题三:打印由序列生成的等腰三角形或其他形状

  • 该类问题同样采用多层嵌套循环来解决。以打印数字构成的等腰三角形为例,核心思路是让每行的数字序列与行号相关联,并通过两侧的空格调整图形位置。在实际编程过程中,灵活运用循环变量和条件判断,可轻松扩展至打印其他由序列生成的图形,比如等腰梯形、倒三角形等。在处理更复杂的图形时,可能还需要结合数学公式或算法进一步优化循环结构和输出逻辑。

对于上述所有问题,其通用解题策略在于理解和掌握如何利用循环结构(如for循环)来控制图形的行数和列数,以及如何结合条件判断语句进行字符的选择和计数。对于字符序列构建图形的问题,关键是确定字符排列的规律,并据此设计循环体内的操作。此外,通过调整循环内外的代码逻辑,可以适应不同要求下的图形输出任务,实现对多种形态的字符图形的有效绘制。

感谢

如若本文对您的学习或工作有所启发和帮助,恳请您给予宝贵的支持——轻轻一点,为文章点赞;若觉得内容值得分享给更多朋友,欢迎转发扩散;若认为此篇内容具有长期参考价值,敬请收藏以便随时查阅。

每一次您的点赞、分享与收藏,都是对我持续创作和分享的热情鼓励,也是推动我不断提供更多高质量内容的动力源泉。期待我们在下一篇文章中再次相遇,共同攀登知识的高峰!

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2799452.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

解决弹性布局父元素设置高自动换行,子元素均分高度问题(align-content: flex-start)

案例&#xff1a; <view class"abc"><view class"abc-item" v-for"(item,index) in 8" :key"index">看我</view> </view> <style lang"less">.abc{height: 100px;display: flex;flex-wrap: …

【深入理解设计模式】 工厂设计模式

工厂设计模式 工厂设计模式是一种创建型设计模式&#xff0c;它提供了一种在不指定具体类的情况下创建对象的接口。在工厂设计模式中&#xff0c;我们定义一个创建对象的接口&#xff0c;让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到其子类。 工厂设计模式的目…

centos 9 编译安装 LAMP wordpress

[rootlocalhost ~]# ll 总用量 655760 -rw-------. 1 root root 1040 2月 17 16:57 anaconda-ks.cfg drwxr-xr-x. 29 501 games 4096 2月 21 11:00 apr-1.7.4 -rw-r--r--. 1 root root 1122147 2月 21 10:57 apr-1.7.4.tar.gz drwxr-xr-x. 21 501 games …

四、分类算法 - 随机森林

目录 1、集成学习方法 2、随机森林 3、随机森林原理 4、API 5、总结 sklearn转换器和估算器KNN算法模型选择和调优朴素贝叶斯算法决策树随机森林 1、集成学习方法 2、随机森林 3、随机森林原理 4、API 5、总结

【Python】2019年蓝桥杯省赛真题——完全二叉树的权值

蓝桥杯 2019 省 A&B&#xff1a;完全二叉树的权值 题目描述 给定一棵包含 N N N 个节点的完全二叉树&#xff0c;树上每个节点都有一个权值&#xff0c;按从上到下、从左到右的顺序依次是 A 1 , A 2 , ⋯ A N A_1,A_2, \cdots A_N A1​,A2​,⋯AN​&#xff0c;如下图所…

《咸鱼之王》简单拆解图(持续更新)

文章目录 一、 介绍二、 角色设定阿咸咸将 三、游戏拆解 一、 介绍 《咸鱼之王》是一款由阿咸工作室开发的手机游戏&#xff0c;战斗方式为回合制卡牌对战&#xff0c;同时玩家点击屏幕可以为阵容提供助攻。该游戏于2021年3月4日公测。 在游戏中&#xff0c;玩家将化身主角阿…

Spring学习笔记(三)--Spring中的Bean的管理

一、什么是Bean Bean是注册到Spring容器中的Java类&#xff0c;控制反转和依赖注入都是通过Bean实现的&#xff0c;任何一个Java类都可以是一个Bean。Bean由Spring进行管理&#xff0c;可以通过xml文件对bean进行配置和管理。 二、BeanFactory接口和ApplicationContext接口&a…

重新安装VSCode后,按住Ctrl(or Command) 点击鼠标左键不跳转问题

重新安装VSCode后&#xff0c;按住Ctrl&#xff08;or Command&#xff09; 点击鼠标左键不跳转问题 原因&#xff1a;重新安装一般是因为相应编程语言的插件被删除了或还没有下载。 本次是由于Python相关的插件被删除了&#xff0c;因此导致Python无法跳转。 解决办法 在vs…

船运物流管理系统|基于springboot船运物流管理系统设计与实现(源码+数据库+文档)

船运物流管理系统目录 目录 基于springboot船运物流管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、管理员登录 2、货运单管理 3、公告管理 4、公告类型管理 5、新闻管理 6、新闻类型管理 四、数据库设计 1、实体ER图 五、核心代码 六、论文参考 …

ElasticSearch语法

Elasticsearch 概念 入门学习: Index索引>MySQL 里的表(table)建表、增删改查(查询需要花费的学习时间最多)用客户端去调用 ElasticSearch(3 种)语法:SQL、代码的方法(4 种语法) ES 相比于 MySQL&#xff0c;能够自动帮我们做分词&#xff0c;能够非常高效、灵活地查询内…

【算法 - 动态规划】最长回文子序列

上篇文章中&#xff0c;我们学习一个新的模型&#xff1a; 样本对应模型&#xff0c;该模型的套路就是&#xff1a;以结尾位置为出发点&#xff0c;思考两个样本的结尾都会产生哪些可能性 。 而前篇文章中的 纸牌博弈问题 属于 [L , R]上范围尝试模型。该模型给定一个范围&…

初阶数据结构之---顺序表和链表(C语言)

引言-线性表 线性表&#xff1a; 线性表&#xff08;linear list&#xff09;是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构。线性表在逻辑上是线性结构&#xff0c;也就是说是连续的一条直线。但在物理上并不一定是连续的。线性表在物理上…

UE4 C++联网RPC教程笔记(三)(第8~9集)完结

UE4 C联网RPC教程笔记&#xff08;三&#xff09;&#xff08;第8~9集&#xff09;完结 8. exe 后缀实现监听服务器9. C 实现监听服务器 8. exe 后缀实现监听服务器 前面我们通过蓝图节点实现了局域网连接的功能&#xff0c;实际上我们还可以给项目打包后生成的 .exe 文件创建…

【服务器】服务器推荐

一、引言 在数字世界的浪潮中&#xff0c;服务器作为数据存储和处理的基石&#xff0c;其重要性不言而喻。而在这个繁星点点的市场中&#xff0c;雨云以其独特的优势和超高的性价比&#xff0c;逐渐成为众多企业和个人的首选。今天&#xff0c;就让我带你走进雨云的世界&#…

JAVA高并发——单例模式和不变模式

文章目录 1、探讨单例模式2、不变模式 由于并行程序设计比串行程序设计复杂得多&#xff0c;因此我强烈建议大家了解一些常见的设计方法。就好像练习武术&#xff0c;一招一式都是要经过学习的。如果自己胡乱打&#xff0c;效果不见得好。前人会总结一些武术套路&#xff0c;对…

关于 AC 自动机

什么是 AC 自动机 AC 自动机&#xff0c;全称 Aho-Corasick 自动机&#xff0c;是一种用于字符串搜索的算法&#xff0c;由 Alfred V. Aho 和 Margaret J. Corasick 在 1975 年提出。这个算法是为了解决在一个主文本字符串中查找多个模式字符串&#xff08;或称为“关键词”&a…

吴恩达机器学习全课程笔记第三篇

目录 前言 P42-P48 神经元和大脑 神经网络中的层 更复杂的神经网络 前向传播&#xff08;做出预测&#xff09; P49-P53 代码中的推理 构建一个神经网络 P54-P60 矩阵乘法 TensorFlow框架实现神经网络 前言 这是吴恩达机器学习笔记的第三篇&#xff0c;第二篇笔记…

绿盾限制终端网络访问权限会恢复后,别的网站访问正常就是无法访问钉钉网站和下载东西

环境&#xff1a; Win10 专业版 钉钉7.5.5 绿盾7.0 问题描述&#xff1a; 绿盾限制终端网络访问权限会恢复后&#xff0c;别的网站访问正常就是无法访问钉钉网站和下载东西 解决方案&#xff1a; 排查方法 1.重置浏览器或者更换浏览器测试&#xff08;未解决&#xff09…

nc开发刚导入项目eclipse出现莫名其妙的错误,红叉,感叹号,文件missing

解决类出现红叉 解决感叹号&#xff0c;文件missing 其他问题 右上角的视图&#xff0c;要选择java&#xff0c;如果是javaEE也会有一些文件没有展示出来。

QYWX企业微信的公告信息限制保存pdf的破解

公司使用企业微信好几年&#xff0c;重大的消息使用公告信息这个模块。可重要的消息无法保存&#xff0c;只能在线收藏。这个玩意只考虑到了维护企业利益&#xff0c;无视员工利益。 后来发现可以利用windows的虚拟打印机&#xff0c;将公告打印成pdf。 用了一段时间&#xf…