力扣--LCR 180.文件组合

题目

待传输文件被切分成多个部分,按照原排列顺序,每部分文件编号均为一个 正整数(至少含有两个文件)。传输要求为:连续文件编号总和为接收方指定数字 target 的所有文件。请返回所有符合该要求的文件传输组合列表。

注意,返回时需遵循以下规则:

复制代码
每种组合按照文件编号 升序 排列;
不同组合按照第一个文件编号 升序 排列。

示例 1:

输入:target = 12

输出:[[3, 4, 5]]

解释:在上述示例中,存在一个连续正整数序列的和为 12,为 [3, 4, 5]。

示例 2:

输入:target = 18

输出:[[3,4,5,6],[5,6,7]]

解释:在上述示例中,存在两个连续正整数序列的和分别为 18,分别为 [3, 4, 5, 6] 和 [5, 6, 7]。

提示:

复制代码
1 <= target <= 10^5

代码

滑动窗口

class Solution {

public int[][] fileCombination(int target) {

List<int[]> res = new ArrayList<>();

int i = 1, j = 1;

int sum = 1;

while(i <= target/2){

if(sum < target){

j++;

sum = sum + j;

} else if(sum > target){

sum = sum - i;

i++;

} else {

int[] temp = new int[j - i + 1];

int index = 0;

for(int k = i; k <= j; k++){

temp[index++] = k;

}

sum = sum - i;

i++;

j++;

sum = sum + j;

res.add(temp);

}

}

复制代码
    return res.toArray(new int[res.size()][]);
}

}

时间复杂度:O(n)

额外空间复杂的:O(1)

相关推荐
东离与糖宝14 分钟前
Gradle 9.4+Java26:大型项目构建提速100倍实战配置
java·人工智能
罗湖老棍子21 分钟前
花神游历各国(信息学奥赛一本通- P1550)(洛谷-P4145)
数据结构·算法·线段树·势能数·区间开平方根 区间查询
Mr_Xuhhh23 分钟前
LeetCode 热题 100 刷题笔记:数组与排列的经典解法(续)
算法·leetcode·职场和发展
想进大厂的小徐26 分钟前
maven的子模块和子pom的区别
java·maven
pengles31 分钟前
基于RuoYi-Vue-Plus项目实现移动端项目
java·vue.js·uni-app
希望永不加班31 分钟前
SpringBoot 编写第一个 REST 接口(Get/Post/Put/Delete)
java·spring boot·后端·spring
菜菜小狗的学习笔记39 分钟前
Java SE(一)内部类、Lambda表达式、Stream流
java·开发语言
码云数智-园园40 分钟前
Java中的重载(Overload)与重写(Override):本质区别、场景与注意事项
java·开发语言
yxm263366908141 分钟前
洛谷P1217回文质数
java·开发语言
金斗潼关41 分钟前
java反序列化入口方法介绍
java·开发语言·jvm·序列化·反序列化