所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

源代码:#include
int a,p;
int m[40][40];
void pr(int a)
{
int i,j;
for(i=0;i<=2*a;i++)
{
for(j=0;j<=2*a;j++)
{
if(i<=a)
{
if(j>=i&&j<=(2*a)-i)
{
m[i][j]=1;
}
else
{
m[i][j]=0;
}
}
else
{
m[i][j]=m[2*a-i][j];
}
if(m[i][j]==1)
{
printf("*");
}
else
{
printf(" ");
}
}
printf("\n");
}
}
int main()
{
int n,q;
scanf("%d",&n);
for(a=1;a {
int y;
y=((2*a*a)+(2*a)+1);
if(y>n)
{
a=a-1;
p=n-y;
break;
}
else if(y==n)
{
p=0;
break;
}
else
{
;
}
}
int u;
pr(a);
printf("%d",p);
return 0;
}

基础题:

打开网易新闻 查看精彩图片