标签:count 输出 cur 以下 图案 行号 星星 空格 row
输出以下图案:
*
***
*****
*******
*****
***
*
答案解析:
该题目需要关心当前行对应的从最左边到第一颗*
的空格数量以及星星数量。将该题分为两个部分,前面4行和后面3行来进行拆分。
前4行中:
第一行:行号为0, 空格数为3,星星数量为1;
第二行:行号为1, 空格数为2, 星星数量为3;
第三行:行号为2, 空格数为1, 星星数量为5;
第四行:行号为3, 空格数为0,星星数量为7;
则我们可以推出两组关系,即行号和空格数量关系为:空格数 = 3 - 行号 。行号与星星的关系为:星星数 = 2 * 行号 + 1
后三行中:
第一行:行号为0,空格数为1,星星数量为5;
第二行:行号为1, 空格数为2, 星星数量为3;
第三行:行号为2, 空格数为3,星星数量为1;
则我们推出两组关系,即行号与数量的关系:空格数 = 行号 + 1。行号与星星的关系:星星数 = 7 - 2 * (行号+1)
基于上面的关系,我们写出如下代码:
代码示例:
#include <stdio.h>
int main()
{
int cur_row, space_count, start_count;
//输出前4行内容
for (cur_row = 0; cur_row < 4; cur_row++)
{
//计算当前行空格数量,并且进行打印
for (space_count = 3 - cur_row; space_count > 0; space_count--)
{
printf(" ");
}
//计算当前行*数量,并且进行打印
for (start_count = 2 * cur_row + 1; start_count > 0; start_count--)
{
printf("*");
}
printf("\n") ;
}
//输出后三行
for (cur_row = 0; cur_row < 3; cur_row++)
{
for (space_count = cur_row + 1; space_count > 0; space_count--)
{
printf(" ");
}
for (start_count = 7 - 2 * (cur_row + 1); start_count > 0; start_count--)
{
printf("*");
}
printf("\n");
}
return 0;
}
运行截图:
标签:count,输出,cur,以下,图案,行号,星星,空格,row 来源: https://www.cnblogs.com/weiyidedaan/p/13660919.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。