题目要求:
多行输入,整数在2-20之间,打印x型图案,输入数同时表打印的行数和反斜线的长度
知识点:循环,难度不高,找规律即可。
思路:
运用了与二分查找相近的思路,mid查找left与right,是个笨方法,后续有改进空间。
- 设输入数为x(表行数与每行长度)设定左边为left,右边为right,运用mid查找
- left不大于x,每行+1,right不小于1,每行-1
- mid用于每行遍历,每次+1,不大于x
- mid等于left或right时即打印*
由此得到两条反斜线
流程图:
![](https://img-blog.csdnimg.cn/direct/8f067851cc29459795e09684a2f09905.png)
代码:
#include <stdio.h>
int main()
{
int x=0;
while (scanf("%d",&x)!=EOF)//EOF要和前置语句连接在一起
{
int left=1;
int right=x;
for(int j=0;j<x;j++)
{
for (int mid =1;(right>0) &&(left<=x)&&(mid<=x);mid++ )
{
if(mid==left || mid==right)//当二者相同时不知道是不是只会打一颗
{
printf("*");
}
else {
printf(" ");
}
}
left++,right--;
printf("\n");
}
}
}
通过,用时1ms,内存188kb,排名62。