方法一 拆分法
拆分法(将*和空格分开来考虑,简化问题)(菱形大小无上限)
#include<stdio.h>
int main()
{
int n = 0;//输入上半行的行数
scanf("%d",&n);
int i = 0;
//打印上半行
for (i = 0; i < n; i++)
{
//打印空格
int j = 0;
for (j = 0; j < n - 1-i; j++)
{
printf(" ");
}
//打印*
for (j = 0; j < 2 * i + 1; j++)
{
printf("*");
}
printf("\n");
}
//打印下半行
for (i = 0; i < n - 1; i++)
{
int j = 0;
//打印空格
for (j = 0; j <= i; j++)
{
printf(" ");
}
//打印*
for (j = 0; j < 2*(n-1-i)-1; j++)
{
printf("*");
}
printf("\n");
}
return 0;
}
方法二 整体法
//整体法(将每一行当作整体考虑)(数组+指针)
#include<stdio.h>
int main()
{
int n = 0;
scanf("%d",&n);//输入上半行的行数
char arr[100] = { 0 };//这里的数组大小决定菱形大小的上限
int j = 0;
for (j = 0; j < 2 * n + 1; j++)
arr[j] = ' ';//赋值数组
//arr[2*n+1]='\0';//此行可加可不加,因为初始将arr数组已经赋过值0,就相当于赋值'\0'
char* left=&arr[n],*right=&arr[n];//arr[n]是中间元素
while(left>=arr)//打印上半行
{
*right = '*';
*left = '*';
printf("%s\n",arr);
right++;
left--;
}
while (left < &arr[n])//打印下半行
{
right--;
left++;
*right = ' ';
*left = ' ';
printf("%s\n",arr);
}
return 0;
}
如果是用整个行数进行运算,请自行替换n的表达式,将其改为(n+1)/2,n要为奇数。