力扣--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)

相关推荐
陌上花开࿈7 分钟前
用户登录认证
java·开发语言·前端
小小李程序员27 分钟前
java乱序执行实验
java·开发语言·python
怒放de生命20101 小时前
jenkins 出现 Jenkins: 403 No valid crumb was included in the request
java·servlet·jenkins
古希腊掌管学习的神1 小时前
[机器学习]AdaBoost(数学原理 + 例子解释 + 代码实战)
人工智能·python·算法·机器学习
山河君1 小时前
音频进阶学习八——傅里叶变换的介绍
学习·算法·音视频·信号处理
重生之我在VS写bug1 小时前
【C语言的奥秘11】指针知识点总结(续)
c语言·开发语言·算法
shaoweijava1 小时前
企业车辆管理系统(源码+数据库+报告)
java·数据库·spring boot·mysql
Java&Develop1 小时前
ShardingSphere-多表关联
java·数据库
勤劳的进取家2 小时前
高斯混合模型及最大期望算法(EM)聚类
人工智能·python·算法·机器学习
eternal__day2 小时前
数据结十大排序之(选排,希尔,插排,堆排)
java·数据结构·算法·推荐算法