C++ code:for loop designs
1 用for循环编出系列图形

该图形一共10行,每一行增加一个字符,所以应循环10次,每次输出一行。其循环模式为:
for(int i=;i<=;++i)
{
输出第i行
换行
}
我们注意到,每一行长度的变化正好与循环变量i同步,故可以依赖于i。我们注意到第i行的M字符数与i的关系:

所以可以得到“输出第i行”的循环为:
for (int j = ; j <= i; ++j)
cout << "M";
将内、外循环嵌套起来,得到完整代码如下:
#include<iostream>
using namespace std;
int main()
{
for (int i = ; i <= ; ++i)
{
for (int j = ; j <= i; ++j)
cout << "M";
cout << endl;
}
cin.get();
return ;
}
对于这种字符图形,一般用两重循环,外循环遍历所有行,内循环遍历行中每个字符。
输出结果如我们所料:

2 画出下列图案

按照上面的分析方法,一共10行,这次要考虑没行中,先输出若干个空格,所以其外循环为:
for(int i=;i<=;++i)
{
输出若干空格
输出若干M
换行
}
略加思考,列出在第i行,其空格数,M数与i的关系为:

即第i行的空格数为i-1个,M数为21-2i。即在第i行输出空格和输出M字符的内循环分别为:
for (int j = ; j <= i; ++j)
cout << " ";
for (int k = ; k <= - * i; ++k)
cout << "M";
合起来构成一个完整的程序如下:
#include<iostream>
using namespace std;
int main()
{
for (int i = ; i <= ; ++i)//控制行数
{
for (int j = ; j <= i; ++j)//输出每行空格数
cout << " ";
for (int k = ; k <= - * i; ++k)//输出每行M字符数
cout << "M";
cout << endl;
}
cin.get();
return ;
}
运行结果:

3 画出下列图形

按照上面的例子,得到相似的外循环形式:
for(int i=;i<=;++i)
{
输出若干空格
输出若干M
换行
}
若要输出A起头依序的n(n<27)个字母,我们可以:
for (int i = ; i <= n; ++i)
cout << 'A' + i - ;
或者
for (char ch = 'A'; ch < 'A' + n; ++ch)
cout << ch;
'A' + i - 1的值为整数,因为'A'是char(字符)类型,而i-1是整数类型,整数的表示范围大于字符,所以,结果的类型为整形。为了输出该整数所对应的字符,需要整数表达式做一下转换,转换的形式是将整数表达式括起来,前边加上要转成的类型名char。
知道了行中要输出的字符个数,就可以实现上面的图形了。现在我们还是从分析每一行中的空格数和字符数与第i行之间的关系着手:

即第i行的空格数为10-i个,字符数为2*i-1。因此,输出空格数和字符数的内循环分别为:
for (int j = ; j <= - i; ++j)
cout << " ";
for (char ch = 'A'; ch < 'A' + *i-; ++ch)
cout << ch;
合起来的完整代码为:
#include<iostream>
using namespace std;
int main()
{
for (int i = ; i <= ; ++i)
{
for (int j = ; j <= - i; ++j)
cout << " ";
for (char ch = 'A'; ch < 'A' + * i - ; ++ch)
cout << ch;
cout << endl;
}
cin.get();
return ;
}
运行结果:

C++ code:for loop designs的更多相关文章
- C++ code:More Loop Designs
1 逻辑判断 对于逻辑判断问题,一般都要考虑全部的可能性,然后从这些可能性中按条件逐一排查,直到最后获得某个结论. [百钱买百鸡问题] 问题描述: 雄鸡(cock)7元一只,母鸡(hen)5元一只, ...
- VS Code:让你工作效率翻倍的23个插件和23个编辑技巧
VS Code:让你工作效率翻倍的23个插件和23个编辑技巧 总结了一些平时常用且好用的 VS Code 的插件和编辑技巧分享出来. 文章详情可查阅我的博客:lishaoy.net ,欢迎大家访问. ...
- Windows could not set the offline local information.Error code:0X80000001解决方法
我的笔记本是联想Y460(白色) 昨天在重装系统的时候遇到如下错误:Windows could not set the offline local information.Error code:0X8 ...
- Code:Blocks 中文乱码问题原因分析和解决方法
下面说说修改的地方. 1.修改源文件保存编码在:settings->Editor->gernal settings 看到右边的Encoding group Box了吗?如下图所示: Use ...
- Libevent:4event loop
一:运行loop 一旦一些events在event_base注册之后(下一节会讨论如何创建和注册events),就可以使Libevent等待events,并且在events准备好时能够通知 ...
- HTML Standard系列:Event loop、requestIdleCallback 和 requestAnimationFrame
HTML Standard系列:Event loop.requestIdleCallback 和 requestAnimationFrame - 掘金 https://juejin.im/post/5 ...
- JavaScript 运行机制详解:Event Loop
参考地址:http://www.ruanyifeng.com/blog/2014/10/event-loop.html 一.为什么JavaScript是单线程? JavaScript语言的一大特点就是 ...
- JavaScript:event loop详解
之前已经有两篇随笔提到了event loop,一篇是事件机制,一篇是tasks和microtasks,但是里面的event loop都是文字描述,很难说细,逻辑也只是简单的提了一遍.其实之前也是通过阮 ...
- VS Code:快捷方式
转于:vscode: Visual Studio Code 常用快捷键 博主:魚魚 更多操作参见官网:https://code.visualstudio.com/docs/getstarted/key ...
随机推荐
- Linux下快速分区格式化大于2T磁盘存储
在生产环境中,我们会遇到分区大于2T的磁盘(比如:添加一个10TB的存储),由于MBR分区表只支持2T磁盘,所以大于2T的磁盘必须使用GPT分区表,而我们在做raid时会划分多个VD来进行装系统,但系 ...
- 元组&哈希&字典
1.元组(1)特性:不可变(不能修改.添加.删除),可以做切片 元组本身不可变,如果元组中还包含其他可变元素,这些可变元素可以改变(元组里套用列表,列表中的值可变)(2)功能: index count ...
- HDU1199 动态线段树 // 离散化
附动态线段树AC代码 http://acm.hdu.edu.cn/showproblem.php?pid=1199 因为昨天做了一道动态线段树的缘故,今天遇到了这题没有限制范围的题就自然而然想到了动态 ...
- JVM调优命令-jstack
jstack jstack用于生成java虚拟机当前时刻的线程快照.线程快照是当前java虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁 ...
- Kanboard简单的可视化任务板,项目管理
采用docker安装 简单快捷 下载 docker pull kanboard/kanboard:latest 运行 docker run -d --name kanboard -p 10080:80 ...
- CodeBblock 常用快捷键 (最常用)
==日常编辑== • 按住Ctrl滚滚轮,代码的字体会随你心意变大变小. • 在编辑区按住右键可拖动代码,省去拉(尤其是横向)滚动条之麻烦:相关设置:Mouse Drag Scrolling. • C ...
- HDU - 3002 King of Destruction(最小割)
http://acm.hdu.edu.cn/showproblem.php?pid=3002 最小割模板 #include<iostream> #include<cmath> ...
- python 小程序,替换文件中的字符串
[root@PythonPC ~]# cat passwd root:x:::root:/root:/bin/bash bin:x:::bin:/bin:/sbin/nologin daemon:x: ...
- u-boot移植(十)---代码修改---支持nor flash
一.问题定位 开发板重启后打印了2个提醒和一个错误,caches的提醒先不看,看看flash和nand下面的提醒,bad CRC,Using default enviroment,我们可以定位Usin ...
- CF875D High Cry
传送门 题目要求合法的区间个数,这里考虑用总区间个数减去不合法的个数 假设某个数为区间最大值,那么包含这个数的最长区间内,所有数小于他并且所有数没有这个最大值没有的二进制位,可以按位考虑每个数\(i\ ...