打印沙漏!!就差最后一步!!求大神找找错误
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印*****
***
*
***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
输入格式:
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。
输出格式:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
输入样例:
19 *
输出样例:
*****
***
*
***
*****
2
#include<stdio.h>
int main()
{
int n;
char ch;
scanf("%d %c",&n,&ch);
if(n>0&&n<=1000)
{
int s,i;
s=1;
i=1;
while(s<=n)
{
i+=2;
s+=2*i;
}
s-=2*i;
i-=2;
int j;
for(j=0;j<(i-1)/2;j++)
{
int k;
for(k=0;k<j;k++)
{
printf(" ");
}
int l;
for(l=0;l<i-2*j;l++)
{
printf("%c",ch);
}
printf("\n");
}
for(j=(i-1)/2;j>=0;j--)
{
int m;
for(m=0;m<j;m++)
{
printf(" ");
}
int n;
for(n=0;n<i-2*j;n++)
{
printf("%c",ch);
}
printf("\n");
}
if(s<n)
printf("%d",n-s);
}
return 0;
}
结果都对,但是提交后显示最小的n答案是错误的,可没毛病a,n=1的时候不就只有一个符号嘛
求助求助 我的代码是
输入: 1c
输出:
c
0ac了 n=1的时候你的第一个for循环进不去 最后的魁拔 发表于 2020-4-2 17:14
我的代码是
ac了
哈??啥意思{:10_279:} 墨羽岚 发表于 2020-4-2 17:38
n=1的时候你的第一个for循环进不去
可是34行那个可以哇,最后只打印出一个不就行了{:10_266:} 白丁俗客 发表于 2020-4-2 18:04
哈??啥意思
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
int num;
char sign;
int sum_1 = 0;
scanf("%d %c",&num,&sign);
//计算最上面一行需要几个符号
int d,sum=0,hangshu = 0;
d = (num-1)/2;//d为抛掉为1个符号剩余的个数
int i,j;
for(i=3;;i+=2)
{
hangshu++;
if((sum = sum+i)>d)
{
//printf("%d\n",i-2);//确定最上层的个数
break;
}
}
int max = i-2;
for(i=2;i<=hangshu;i++)
{
for(j=2;j<=i-1;j++)
{
printf(" ");
}
for(j=1;j<=max;j++)
{
printf("%c",sign);
sum_1 = sum_1 + 1;
}
max -=2;
printf("\n");
}
for(i=1;i<=hangshu;i++)
{
for(j=1;j<=hangshu-i;j++)
{
printf(" ");
}
for(j=1;j<=2*i-1;j++)
{
printf("%c",sign);
sum_1 = sum_1 + 1;
}
printf("\n");
}
printf("%d\n",num-sum_1);
system("pause");
return 0;
}
这是我通过的代码,你输入1 *和你的对比一下就知道了
页:
[1]