#include <stdio.h>
/*
打印菱形
*
***
*****
*******
*****
***
*
分析
1.菱形一定是奇数行
2.每一行的字符数是相等(星号+空格),等于总行数
3.计算上面一半的星号的出现规律
第n行星号个数=n*2-1
第n行的空格个数=(总行数-(n*2-1) )/2,每行只要打印左边空格
*/
void main(){
int line; //菱形的总行数
int mid;//菱形上半部分的行数
int star;//每行的星号数
int space;//每行的空格数
int i,j;
printf("请输入菱形的行数(奇数):");
scanf("%d",&line);
mid = line/2+1;//上半部分的总行数
for(i=1;i<=mid;i++){
star = 2*i-1; //第i行星号个数
space = (line-star)/2;//第i行星号左边的空格数
//打印空格
for(j=1;j<=space;j++){
printf(" ");
}
//打印星号
for(j=1;j<=star;j++){
printf("*");
}
//换行
printf("\n");
}
//打印下半部分
for(i=mid-1;i>=1;i--){
star = 2*i-1; //第i行星号个数
space = (line-star)/2;//第i行星号左边的空格数
//打印空格
for(j=1;j<=space;j++){
printf(" ");
}
//打印星号
for(j=1;j<=star;j++){
printf("*");
}
//换行
printf("\n");
}
}
第三题:
代码:
#include <stdio.h>
int main()
{
int m,n;
int i,j,total;
printf("请输入行数和三角形个数:");
scanf("%d %d",&m,&n);
total = m*n;
for (i=1;i<=m;i++)
{
for (j=0;j<total;j++)
{
if (j%m < i)
putchar('*');
else
putchar(' ');
}
printf("\n");
}
return 0;
}