华为OD-D卷数的分解

给定一个正整数n,如果能够分解为m(m > 1)个连续正整数之和,请输出所有分解中,m最小的分解。

如果给定整数无法分解为连续正整数,则输出字符串"N"。

输入描述:

输入数据为一整数,范围为(1, 2^30]

输出描述:

比如输入为:

21

输出:

21=10+11

备注:

21可以分解的连续正整数组合的形式有多种

21=1+2+3+4+5+6

21=6+7+8

21=10+11

输出,21=10+11,是最短的分解序列。

题目解析:如果是奇数就很简单,一定能找到相邻的两个数相加为 n,那么剩下的数该怎么处理呢?

因为要找到连续的正整数,而且m最小,那么即使有多种分解方法,在这个m里面的分解数里一定存在所有分解方法中最大的数,例如15可以分为(1+2+3+4+5),或者(4+5+6),那么我们找的结果中包含m中会存在这个最大的6。

这样就好办了,我们只需要从15/2->1开始算,这个最大的数是多少,不断的去试,7可以吗,要保证连续7+6=13<15,再加,7+6+5>18,显然不行。

java 复制代码
import java.util.Deque;
import java.util.LinkedList;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
//        int n = 10;
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        // n 为奇数
        // deque前后都可以取元素,方便
        Deque<Integer> deque = new LinkedList<>();
        // 标识位,看是否可以拆解成连续数相加
        boolean flag = false;
        // n为奇数
        if (n % 2 == 1) {
            System.out.println(n + "=" + n / 2 + "+" + (n / 2 + 1));
            return;
        } else {
            // n为偶数
            int start = n / 2;
            int sum = 0;
            // 从大数开始试
            for (int i = start; i > 0; i--) {
                deque.add(i);
                sum += i;
                if (sum == n) {
                    flag = true;
                    break;
                } else if (sum > n) {
                    sum -= deque.peek();
                    deque.poll();
                }
            }
        }
        // 不能拆解输出"N"
        if(flag == false){
            System.out.println("N");
            return;
        }
        // 可以的话从deque中取元素出来,注意顺序
        System.out.print(n + "=");
        while (deque.size() > 1) {
            System.out.print(deque.pollLast());
            System.out.print("+");
        }
        System.out.println(deque.pollLast());
    }
}
相关推荐
csdn2015_15 分钟前
MyBatis Generator 核心配置文件 generatorConfig.xml 完整配置项说明
java·mybatis
追逐梦想的张小年18 分钟前
JUC编程03
java·开发语言·idea
万邦科技Lafite28 分钟前
一键获取京东商品评论信息,item_reviewAPI接口指南
java·服务器·数据库·开放api·淘宝开放平台·京东开放平台
indexsunny38 分钟前
互联网大厂Java面试实战:从Spring Boot到微服务架构的技术问答解析
java·spring boot·redis·微服务·kafka·jwt·flyway
蓁蓁啊42 分钟前
C/C++编译链接全解析——gcc/g++与ld链接器使用误区
java·c语言·开发语言·c++·物联网
sheji34161 小时前
【开题答辩全过程】以 基于SpringBoot的疗养院管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
tb_first1 小时前
万字超详细苍穹外卖学习笔记2
java·jvm·数据库·spring·tomcat·maven
短剑重铸之日1 小时前
《设计模式》第六篇:装饰器模式
java·后端·设计模式·装饰器模式
像少年啦飞驰点、1 小时前
零基础入门 Spring Boot:从‘Hello World’到可上线微服务的完整学习路径
java·spring boot·web开发·编程入门·后端开发