90 和为s的连续正数序列

问题描述:输入一个正整数target,输出所有和为target的连续正整数序列(至少包含两个数),序列内的数字大小由小到大排列,不同序列按照首个字母从小到大排列。

for循环求解:对于for循环而言复杂度为n2较高。

java 复制代码
public List<List<Integer>>sumS(int target)
{
List<List<Integer>> res=new List<>();
for(int i=1;i<target/2;i++)
{
int sum=i;
List<Integer>list=new LinkedList<>();
list.add(i);
for(int j=i+1;j<target/2;j++)
{
if(sum+j>target)
break;
}else if(sum+j==target)
{
list.add(j);
res.add(list);
}else
{
sum+=j;
list.add(j)
}
}
​​​​​​​return res;
}

滑动窗口解决:定义一个sum(int类型)表示从左left到右right这个区间中的和,若sum小于target,则right右移,sum+nums[target],若大于taget,则left左移,若等于,则更新价收入数组中。

java 复制代码
public List<List<Integer>>sumS(int target)
{
int left=1;
int right=2;
int sum=left+right;
List<int[]>res=new LinkedList<>();
while(left<target/2)
{
if(sum<target)
{
right++;
sum+=right;
}else if(sum>target)
{
sum-=left;
left++;
}else
{
int []array=new int[right-left+1];
for(int i=0;i<array.length;i++)
{
array[i]=left+i;
}
res.add(array);
}
}
return res.toArray(new int[res.size()][]);
}
相关推荐
007张三丰5 分钟前
软件测试专栏(5/20):自动化测试入门指南:从零开始构建你的第一个测试框架
自动化测试·python·算法·压力测试·测试框架
李老师的Java笔记7 分钟前
深度解析 | SpringBoot源码解析系列(五):@ConfigurationProperties | 配置绑定核心原理+实战避坑
java·spring boot·后端
Zachery Pole11 分钟前
根据高等代数与数分三计算线性回归中的w
算法·回归·线性回归
❀͜͡傀儡师12 分钟前
SpringBoot 4.0新特性Resilience重试机制和并发限制
java·spring boot·spring
得一录27 分钟前
星图·全参数调试qwen3.1-B
深度学习·算法·aigc
yyjtx27 分钟前
DHU上机打卡D22
算法
plus4s29 分钟前
2月14日(76-78题)
c++·算法·图论
pzx_00136 分钟前
【论文阅读】Attention Is All You Need
论文阅读·算法
-To be number.wan39 分钟前
算法学习日记 |贪心算法
c++·学习·算法·贪心算法
叙白冲冲39 分钟前
JAVA中栈的使用
java·开发语言