ECNU 3529 梵高先生

ECNU 3529 梵高先生

链接

https://acm.ecnu.edu.cn/problem/3529/

题目

单点时限: 1.0 sec

内存限制: 256 MB

谁的父亲死了
请你告诉我如何悲伤
谁的爱人走了
请你告诉我如何遗忘
——李志《梵高先生》

2009年的最后一天 在义乌隔壁酒吧 李志为了还做唱片欠下来的20W 巡回35场演出 在这晚完成 喝醉了的逼哥哽咽着唱完梵高先生 说最后一次唱这歌。他粗鲁的打断了大家的合唱,然后用最沙哑的嗓音唱了起来,哪天,唯一和他合音的只有一只狗。

抬头再看了一眼星空和黑夜,今晚的星星变成了一个三角形的样子,像这样:

1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
...
现在给你一个正整数n,请你给出星空的前n行。

输入格式
输入文件共一行,包含一个正整数n(1<=n<=20)。

输出格式
输出文件共n行,即星空的前n行。每行包含若干正整数,这些正整数之间用一个空格隔开(不能有多余的空格),最后一个正整数后面没有空格。

样例
input
4
output
1
1 1
1 2 1
1 3 3 1

思路

开新坑了,ECNU,华东师大的OJ,这是第一道题,是个水题,一堆文字描述略去,是个杨辉三角。
如果打算要更快,直接打表,因为输入只要求到20,这里还是以学习为重,用常规思路。
先建立数组,从答案中可以发现,左侧和右侧都是1,中间的数字都是上面两个数字的和,这里用递归即可,需要考虑的是要注意输出格式,套一个if即可。此类题目就是,每一行都与上一行有特定关系,只需要注意到关系,并保证数据格式即可。

代码

  public static void fun() {
    int n;
    Scanner sc = new Scanner(System.in);
    n = sc.nextInt();
    int[][] a = new int[n][n + 1];
    for (int i = 0; i < n; i++) {
      a[i][0] = 1;
      a[i][i] = 1;
    }
    for (int i = 2; i < n; i++) {
      for (int j = 1; j < i; j++) {
        a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
      }
    }
    for (int i = 0; i < n; i++) {
      for (int j = 0; j < i + 1; j++) {
        System.out.print(a[i][j]);
        if (j != i) {
          System.out.print(" ");
        }
      }
      if (i != n - 1) {
        System.out.println();
      }
    }
  }
posted @ 2021-01-10 19:48  cheng102e  阅读(118)  评论(0编辑  收藏  举报