目录结构
1.题目
输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)。
序列内的数字由小到大排列,不同序列按照首个数字从小到大排列。
示例:
输入:target = 9
输出:[[2,3,4],[4,5]]
输入:target = 15
输出:[[1,2,3,4,5],[4,5,6],[7,8]]
限制:
1 <= target <= 10^5
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/he-wei-sde-lian-xu-zheng-shu-xu-lie-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
2.题解
枚举。
public class Offer57_2 {
@Test
public void test() {
System.out.println(Arrays.deepToString(findContinuousSequence(15)));
}
public int[][] findContinuousSequence(int target) {
List<int[]> list = new ArrayList<>();
for (int i = 1; i <= target / 2 + 1; i++) {
int tmpSum = 0;
for (int j = i; j <= target / 2 + 1; j++) {
tmpSum += j;
if (tmpSum == target) {
int[] tmp = new int[j - i + 1];
for (int k = i; k <= j; k++) {
tmp[k - i] = k;
}
list.add(tmp);
break;
}
if (tmpSum > target) {
break;
}
}
}
return list.toArray(new int[list.size()][]);
}
}