半数序列集

博客围绕数字半数序列集展开,给定数字n,按规则生成半数序列集,即右边添加不超最近添加数一半的自然数,直至无法添加。给出输入输出要求及样例,最后展示了代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

给定数字n,n的半数序列集是(1)在 n 的右边加上一个自然数,但该自然数不能超过最近添加的数的一半,这样生了新的序列;(2)按此规则进行处理,直到不能再添加自然数为止。例如,4的半数序列集是{4,4 2,4 2 1,4 1}。

输入

一个整数 n,(0<n<=50)。

输出

按照数字降序,输出集合所有序列,每个序列一行,每个数字后面跟一个空格。

样例输入

6

样例输出

6 3 1
6 3
6 2 1
6 2
6 1

代码实现
import java.util.Scanner;
public class Main {
        int n;
        int[] A;
    public Main() {
        Scanner s=new Scanner(System.in);
        n=s.nextInt();
        A=new int[n]; A[0]=n;
        Search(1);
    }
    void Search(int pos) {
        for(int i=A[pos-1]/2;i>=1;i--) {
            A[pos]=i;
            Search(pos+1);    
        }
        for(int k=0;k<pos;k++) System.out.print(A[k]+" ");
        System.out.println();
    }
    public static void main(String[] args) {
        Main h=new Main();
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

callmeCassie

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值