也许放晴会比较好一点


私信TA

用户名:uq_16654036368

访问量:1684

签 名:

等  级
排  名 786
经  验 3600
参赛次数 0
文章发表 34
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

limit_max = 21
max_point = 200

# 行下标r代表直线数目,列下标c代表交点数目,
# point[r][c]的值(0,1)则代表交点数是否存在
point = [[0] * max_point for _ in range(limit_max)]

# first
for r in range(limit_max):
    point[r][0] = 1  # 对任意的r,当所有的直线互相平行时,c==0;
for r in range(2, limit_max):
    c = r * (r - 1) // 2
    point[r][c] = 1

# second
for m in range(2, limit_max):
    for n in range(m - 1, 1, -1):
        n_part = m - n
        for c in range(n_part * (n_part - 1) // 2 + 1):
            if point[n_part][c] == 1:
                point[m][n * n_part + c] = 1

while True:
    try:
        M = int(input())
        for c in range(M * (M - 1) // 2 + 1):
            if point[M][c]:
                print(c, end=' ')
        print()
    except EOFError:
        break


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区