问题描述:
小石坝放学回寝室的路上路过莲湖,于是随手将一颗石头仍进湖里,看着一波波从石头落点向外扩散的涟漪,小石坝思维的火花突然被点燃,假如说石头落入水中的能量(动能势能活化能什么的统统都包含)为正整数n,每往外扩散一圈,能量减一,且做个奇特的假设--水波呈菱形,请将小石坝看到的水波能量分布图描绘出来
输入:
第一行一个正整数n
输出:
画出以数值n为中心的能量分布图
样例输入:
5
样例输出:
1 121 12321 1234321 123454321 1234321 12321 121 1
原因分析:
1.最外层的for里的i可以用来:记录行数,并记录每行数字最大到多少,每行的空格都是 n-i
2.下半部分,可以拿最后一行为第一行,则下半部分的行数应该从 n-1行,行数递减,同时起到第一点的作用
解决方案:
#include<stdio.h>
using namespace std;
int main()
{
int i=1,j,n,f,p;
scanf("%d",&n);
for(i=1;i<=n;i++)
{
for(j=1;j<=n-i;j++)
printf(" ");
for(p=1;p<=i;p++)
printf("%d",p);
for(p=i-1;p>=1;p--)
printf("%d",p);
printf("\n");
}
for(i=n-1;i>=1;i--)
{
for(j=1;j<=n-i;j++)
printf(" ");
for(p=1;p<=i;p++)
printf("%d",p);
for(p=i-1;p>=1;p--)
printf("%d",p);
printf("\n");
}
return 0;
}
。