2个回答
展开全部
#include <stdio.h>
#include <string.h>
#include <malloc.h>
char ** draw(int n);//生成菱形图案的二维数组
void jt(char *p1,char *p2);//地址p1到p2的字符数组(奇数个),从两头向中间交替赋值('*'和空格交替)
int main()
{
int n,i;
char **strs;
while(1)
{
printf("输入一个大于等于3的奇数:");
scanf("%d",&n);
if(n%2==0 || n<3)
printf("不是大于等于3的奇数,请重新输入!\n");
else
break;
}
strs=draw(n);
for(i=0;i<n;i++)
printf("%s\n",strs[i]);
return 0;
}
void jt(char *p1,char *p2)
{
int flag=1;
while(1)
{
if(flag==0)
{
*p2=*p1=' ';
flag=1;
}
else
{
*p2=*p1='*';
flag=0;
}
if(p1==p2)
break;
p1++;
p2--;
}
}
char **draw(int n)
{
int i,mid=n/2,count;
char *p1,*p2;
char *str=(char *)malloc(sizeof(char)*(n+1));
char **strs=(char **)malloc(sizeof(str)*n);
for(i=0;i<n;i++)
{
strs[i]=str;
str=(char *)malloc(sizeof(char)*(n+1));
}
free(str);
memset(strs[mid],'*',n);//中间行
strs[mid][n]=0;
count=0;
for(i=n/2-1;i>=0;i--)//上半边
{
count++;//两头的空格数量
memset(strs[i],32,n);
strs[i][n]=0;
p1=&strs[i][0]+count;
p2=&strs[i][n-1]-count;
jt(p1,p2);
}
count=0;
for(i=n/2+1;i<n;i++)//下半边
{
count++;//两头的空格数量
memset(strs[i],32,n);
strs[i][n]=0;
p1=&strs[i][0]+count;
p2=&strs[i][n-1]-count;
jt(p1,p2);
}
return strs;
}
展开全部
#include "stdio.h"
void prt_diamond( int n )
{
int i,j;
for(i=1;i<=2*n-1;i++)
{
if(i<=n)
{
for(j=0;j<n-i;j++)
printf(" ");
for(;j<n+i-1;j++)
printf("*");
}
else if(i>n)
{
for(j=0;j<i-n;j++)
printf(" ");
for(;j<3*n-1-i;j++) // 2*n-1-(i-n)
printf("*");
}
putchar('\n');
}
}
int main(void)
{
int n;
int repeat, ri;
scanf("%d", &repeat);
for(ri = 1; ri <= repeat; ri++){
scanf("%d", &n);
prt_diamond( n );
printf("-------------------\n" );
}
return 0;
}
void prt_diamond( int n )
{
int i,j;
for(i=1;i<=2*n-1;i++)
{
if(i<=n)
{
for(j=0;j<n-i;j++)
printf(" ");
for(;j<n+i-1;j++)
printf("*");
}
else if(i>n)
{
for(j=0;j<i-n;j++)
printf(" ");
for(;j<3*n-1-i;j++) // 2*n-1-(i-n)
printf("*");
}
putchar('\n');
}
}
int main(void)
{
int n;
int repeat, ri;
scanf("%d", &repeat);
for(ri = 1; ri <= repeat; ri++){
scanf("%d", &n);
prt_diamond( n );
printf("-------------------\n" );
}
return 0;
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询