|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
题目描述
给定一个由n个整数组成的数字串num,并给出一个值S,现请你求出num中元素和大于等于S的最短子串的长度并输出,若没有则输出0。
输入描述
3行,第1行包含1个数字n,代表数字的个数n。
第2行包含n个数字,代表数字串中的每一个数字。
第3行包含1个数字S,代表需要比较的值S
输出描述
1行,包含num中元素和大于等于S的最短子串的长度。
样例1
输入
10
1 2 4 6 3 4 1 2 3 5
9
输出
2
提示
5<=n<=100000,1<=S<=9999998,数字大小不超过100。
我的代码
- #include <iostream>
- using namespace std;
- int a[100005];
- int main()
- {
- int n,s;
- cin>>n;
- for(int i=0;i<n;++i)
- cin>>a[i];
- cin>>s;
- int minl=n,flag=0;
- for(int l=0;l<n;++l){
- for(int r=l;r<l+minl;++r){
- int sum=0;
- for(int i=l;i<=r;++i){
- sum+=a[i];
- }
- if(sum>=s) {
- minl=min(minl,r-l+1);
- flag=1;
- }
- }
- }
- if(!flag){
- minl=0;
- }
- cout<<minl;
- return 0;
- }
复制代码
超时问题,如何简化
解答
这道题可以用滑动窗口(尺取法)高效解决。核心思路是维护一个窗口,通过调整左右边界寻找满足条件的最短子串。
算法步骤:
- 初始化左指针 left=0 和当前和 sum=0,最小长度设为 n+1
- 遍历数组,右指针 right 逐步扩展窗口,将元素加入 sum
- 当 sum >= S 时,尝试缩小左边界,记录最小窗口长度
- 最终若找到合法窗口,输出最小长度;否则输出 0
- #include <iostream>
- #include <vector>
- using namespace std;
- int main() {
- int n;
- cin >> n;
- vector<int> nums(n);
- for (int i = 0; i < n; ++i) cin >> nums[i];
- int S;
- cin >> S;
-
- int left = 0, sum = 0, min_len = n + 1;
- for (int right = 0; right < n; ++right) {
- sum += nums[right];
- while (sum >= S) {
- min_len = min(min_len, right - left + 1);
- sum -= nums[left++];
- }
- }
- cout << (min_len <= n ? min_len : 0) << endl;
- return 0;
- }
复制代码
关键点解释:
1. 滑动窗口通过动态调整左右边界,确保时间复杂度为 O(n)
2. 当窗口和满足条件时,持续缩小左边界以寻找更优解
3. 初始将最小长度设为 n+1 便于后续判断是否存在合法解
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
|
|