题目描述:
输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)。
序列内的数字由小到大排列,不同序列按照首个数字从小到大排列。
示例:
输入:9
输出:[[2,3,4],[4,5]]
直接暴力解决
public int[][] findContinuousSequence(int target) {
List<int[]> result = new ArrayList<>();
for (int i = 1; i <= (target - 1) / 2; ++i) {
int sum = 0;
for (int j = i; ; j++) {
sum += j;
if (sum == target) {
int[] tempArray = new int[j - i + 1];
for (int k = i; k <= j; k++) {
tempArray[k-i] = k;
}
result.add(tempArray);
sum = 0;
break;
} else if (sum > target) {
sum = 0;
break;
}
}
}
return result.toArray(new int[result.size()][]);
}
- 注意i的遍历上限为(target - 1)/ 2