当前位置:   article > 正文

(PTA详解)L1-002. 打印沙漏_l1-002 打印沙漏

l1-002 打印沙漏

思路:采用数学中的奇数和n^2,先求出沙漏上半部分的行数用,2*h*h-1=n(你输入得数,假设是n,此n不等于前面的n),按例题求出是3,然后每行是2*h-1,即5;

先用两个嵌套for循环打印,代码如下:

  1. #include <iostream>
  2. #include <math.h>
  3. using namespace std;
  4. int main()
  5. {
  6. int n;
  7. char a;
  8. while(cin>>n>>a)//保证多组数据输入
  9. {
  10. int h;
  11. h=sqrt((n+1)/2);//由2*h*h-1=n,算出不算沙漏下面,上面需要多少行。
  12. int c=0;
  13. for(int i=h;i>0;i--)
  14. {
  15. for(int j=2*i-1;j>=1;j--)
  16. {
  17. cout<<a;//打印字符
  18. }
  19. cout<<endl;//每行回车
  20. }
  21. for(int i=2;i<=h;i++)//这里
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/人工智能uu/article/detail/935663
推荐阅读
相关标签
  

闽ICP备14008679号