打卡信奥刷题(286)用Scratch图形化工具信奥P1243[普及组/提高] 排序集合

排序集合

题目描述

对于集合 N = { 1 , 2 , ⋯   , n } N=\{1,2,\cdots,n\} N={1,2,,n} 的子集,定义一个称之为“小于”的关系:

S 1 = { X 1 , X 2 , ⋯   , X i } S1=\{X_1,X_2,\cdots,X_i\} S1={X1,X2,,Xi} ( X 1 < X 2 < ⋯ < X i ) (X_1<X_2<\cdots<X_i) (X1<X2<<Xi) S 2 = { Y 1 , Y 2 , ⋯   , Y j } S2=\{Y_1,Y_2,\cdots,Y_j\} S2={Y1,Y2,,Yj} ( Y 1 < Y 2 < ⋯ < Y j ) (Y_1<Y_2<\cdots<Y_j) (Y1<Y2<<Yj),如果存在一个 k k k ( 0 ≤ k ≤ min ⁡ ( i , j ) ) (0\leq k\leq\min(i,j)) (0kmin(i,j)),使得 X 1 = Y 1 , ⋯   , X k = Y k X_1=Y_1,\cdots,X_k=Y_k X1=Y1,,Xk=Yk,且 k = i k=i k=i X k + 1 < Y k + 1 X_{k+1}<Y_{k+1} Xk+1<Yk+1,则称 S 1 S1 S1 “小于” S 2 S2 S2

你的任务是,对于任意的 n ( n ≤ 31 ) n(n\leq31) n(n31) k ( k < 2 n ) k(k<2^n) k(k<2n),求出第 k k k 小的子集。

输入格式

输入文件仅一行,包含两个用空格隔开的自然数, n n n k k k

输出格式

输出文件仅一行,使该子集的元素,由小到大排列。空集输出 0 0 0

样例 #1

样例输入 #1

3 4

样例输出 #1

1 2 3

Scratch实现

在这里插入图片描述

后续

接下来我会不断用scratch来实现信奥比赛中的算法题、Scratch考级编程题实现、白名单赛事考题实现,感兴趣的请关注,我后续将继续分享相关内容

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值