免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3823 | 回复: 14
打印 上一主题 下一主题

有没有更简单的方法得出此图? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-09-03 10:14 |只看该作者 |倒序浏览
用C语言完成如下图所示
                   0
                  0 0
                 0 1 0
                0 1 1 0
               0 1 2 1 0
              0 1 2 2 1 0
             0 1 2 3 2 1 0
            0 1 2 3 3 2 1 0
           0 1 2 3 4 3 2 1 0
          0 1 2 3 4 4 3 2 1 0
         0 1 2 3 4 5 4 3 2 1 0
        0 1 2 3 4 5 5 4 3 2 1 0
       0 1 2 3 4 5 6 5 4 3 2 1 0
      0 1 2 3 4 5 6 6 5 4 3 2 1 0
     0 1 2 3 4 5 6 7 6 5 4 3 2 1 0
    0 1 2 3 4 5 6 7 7 6 5 4 3 2 1 0
   0 1 2 3 4 5 6 7 8 7 6 5 4 3 2 1 0
  0 1 2 3 4 5 6 7 8 8 7 6 5 4 3 2 1 0
0 1 2 3 4 5 6 7 8 9 8 7 6 5 4 3 2 1 0
0 1 2 3 4 5 6 7 8 9 9 8 7 6 5 4 3 2 1 0

#include <stdio.h>
main()
{ int i,j,k,g,aa;
  for(i=0;i<20;i++)
   {
     for(j=1;j<=(19-i);j++)  printf(" ");
     if(i>1)  aa=i/2-1;
     else     aa=0;
     for(k=0;k<=aa;k++)  printf("%d ",k);
     if(i%2==0&&i>1)  printf("%d ",k);
     if(i%2==1&&i>1)  printf("%d %d ",k,k);
     for(g=aa;g>=0&&i>0;g--)  printf("%d ",g);
     printf("\n");
   }
}
这上面是我的写法,有人说有更简单的方法,没查到,请问是什么?

论坛徽章:
0
2 [报告]
发表于 2008-09-03 10:20 |只看该作者
just printf
vortex 该用户已被删除
3 [报告]
发表于 2008-09-04 15:29 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:19:56
4 [报告]
发表于 2008-09-04 15:54 |只看该作者
printf("        0
                  0 0
                 0 1 0
                0 1 1 0
               0 1 2 1 0
              0 1 2 2 1 0
             0 1 2 3 2 1 0
            0 1 2 3 3 2 1 0
           0 1 2 3 4 3 2 1 0
          0 1 2 3 4 4 3 2 1 0
         0 1 2 3 4 5 4 3 2 1 0
        0 1 2 3 4 5 5 4 3 2 1 0
       0 1 2 3 4 5 6 5 4 3 2 1 0
      0 1 2 3 4 5 6 6 5 4 3 2 1 0
     0 1 2 3 4 5 6 7 6 5 4 3 2 1 0
    0 1 2 3 4 5 6 7 7 6 5 4 3 2 1 0
   0 1 2 3 4 5 6 7 8 7 6 5 4 3 2 1 0
  0 1 2 3 4 5 6 7 8 8 7 6 5 4 3 2 1 0
0 1 2 3 4 5 6 7 8 9 8 7 6 5 4 3 2 1 0
0 1 2 3 4 5 6 7 8 9 9 8 7 6 5 4 3 2 1 0
");

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2008-09-04 16:56 |只看该作者
  1. f' 1 = [0]
  2. f' n = prefix ++ middle ++ postfix
  3.   where half = n `div` 2
  4.         (prefix, postfix) = splitAt (half) $ f' (n-1)
  5.         middle = if n `mod` 2 == 1
  6.                   then [half]
  7.                   else [half-1]

  8. f'' _ 0 = []
  9. f'' offset n = f'' (offset+1) (n-1) ++ [thisLine]
  10.   where thisLine = white ++ foldr ((++) . (++" ")) "" items
  11.         white = map (const ' ') [1..offset]
  12.         items = map (show) (f' n)

  13. f n = mapM_ (putStrLn) $ f'' 0 n
复制代码
  1. flw@debian:~/study$ ./ttt.hs 10
  2.          0
  3.         0 0
  4.        0 1 0
  5.       0 1 1 0
  6.      0 1 2 1 0
  7.     0 1 2 2 1 0
  8.    0 1 2 3 2 1 0
  9.   0 1 2 3 3 2 1 0
  10. 0 1 2 3 4 3 2 1 0
  11. 0 1 2 3 4 4 3 2 1 0
  12. flw@debian:~/study$ ./ttt.hs 20
  13.                    0
  14.                   0 0
  15.                  0 1 0
  16.                 0 1 1 0
  17.                0 1 2 1 0
  18.               0 1 2 2 1 0
  19.              0 1 2 3 2 1 0
  20.             0 1 2 3 3 2 1 0
  21.            0 1 2 3 4 3 2 1 0
  22.           0 1 2 3 4 4 3 2 1 0
  23.          0 1 2 3 4 5 4 3 2 1 0
  24.         0 1 2 3 4 5 5 4 3 2 1 0
  25.        0 1 2 3 4 5 6 5 4 3 2 1 0
  26.       0 1 2 3 4 5 6 6 5 4 3 2 1 0
  27.      0 1 2 3 4 5 6 7 6 5 4 3 2 1 0
  28.     0 1 2 3 4 5 6 7 7 6 5 4 3 2 1 0
  29.    0 1 2 3 4 5 6 7 8 7 6 5 4 3 2 1 0
  30.   0 1 2 3 4 5 6 7 8 8 7 6 5 4 3 2 1 0
  31. 0 1 2 3 4 5 6 7 8 9 8 7 6 5 4 3 2 1 0
  32. 0 1 2 3 4 5 6 7 8 9 9 8 7 6 5 4 3 2 1 0
  33. flw@debian:~/study$
复制代码

欢迎光临 FP 版!

[ 本帖最后由 flw 于 2008-9-4 18:08 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2008-09-04 17:07 |只看该作者
原帖由 flw 于 2008-9-4 16:56 发表
f' 1 = "0"
f' n = prefix ++ middle ++ postfix
  where half = n `div` 2
        (prefix, postfix) = splitAt (n-2) $ f' (n-1)
        middle = if n `mod` 2 == 1
                  then " " ++ s ...



这是啥?广告吗?

这东西是咋运行的?

论坛徽章:
0
7 [报告]
发表于 2008-09-04 17:28 |只看该作者
原帖由 flw 于 2008-9-4 16:56 发表
f' 1 = "0"
f' n = prefix ++ middle ++ postfix
  where half = n `div` 2
        (prefix, postfix) = splitAt (n-2) $ f' (n-1)
        middle = if n `mod` 2 == 1
                  then " " ++ s ...


FP版的来做砸场子了

[ 本帖最后由 lgfang 于 2008-9-4 17:33 编辑 ]

论坛徽章:
0
8 [报告]
发表于 2008-09-04 17:30 |只看该作者
flw老大,你到底会多少种编程语言?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
9 [报告]
发表于 2008-09-04 17:42 |只看该作者
原帖由 drog1983 于 2008-9-4 17:30 发表
flw老大,你到底会多少种编程语言?

三四五六七八种吧。

论坛徽章:
0
10 [报告]
发表于 2008-09-04 18:54 |只看该作者

回复 #1 gao_linfeng 的帖子

#include <iostream>
using namespace std;

int main(int arg, char *args[])
{
  if(2 != arg)
     return -1;
// printf("num=%d\n", atoi(args[1]));

  int num = atoi(args[1]);
  int i,j;
  for(i=0; i<num; i++)
  {
    for(j=i;j<num;j++)
      printf(" ");
    for(j=0; j<i+1; j++)
    {
      printf("%d ", (i-abs(i-2*j))/2 );
    }
    printf("\n");
  }
  return 0;
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP