当前位置: 首页 > wzjs >正文

厦门网站制作维护网站数据库维护都是做什么

厦门网站制作维护,网站数据库维护都是做什么,惠阳区城市建设规划局网站,怎样给网站做题目描述 给定一个含有 N N N 个正整数的数组&#xff0c;求出有多少个连续子数组&#xff08;包括单个正整数&#xff09;&#xff0c;其元素之和满足 ∑ ≥ x \sum \geq x ∑≥x。 输入描述 第一行为两个整数 N N N, x x x。其中 0 < N ≤ 1 0 5 0 < N \leq 10^…

题目描述

给定一个含有 N N N 个正整数的数组,求出有多少个连续子数组(包括单个正整数),其元素之和满足 ∑ ≥ x \sum \geq x x

输入描述
第一行为两个整数 N N N, x x x。其中 0 < N ≤ 1 0 5 0 < N \leq 10^5 0<N105, 0 ≤ x ≤ 1 0 7 0 \leq x \leq 10^7 0x107
第二行包含 N N N 个正整数(每个数 ≤ 100 \leq 100 100

输出描述
输出满足条件的连续子数组个数

输入输出示例

示例 1:
输入:

3 7
3 4 7

输出:

4

解释:
满足条件的子数组为:

  • [ 3 , 4 ] [3,4] [3,4] (和为 7 7 7)
  • [ 3 , 4 , 7 ] [3,4,7] [3,4,7] (和为 14 14 14)
  • [ 4 , 7 ] [4,7] [4,7] (和为 11 11 11)
  • [ 7 ] [7] [7] (和为 7 7 7)

解题思路

  1. 问题分析

    • 需要统计所有满足 ∑ i = l r a i ≥ x \sum_{i=l}^r a_i \geq x i=lraix 的区间 [ l , r ] [l,r] [l,r] 的个数
    • 暴力解法时间复杂度为 O ( N 2 ) O(N^2) O(N2),无法通过大规模数据
  2. 优化思路

    • 利用滑动窗口(双指针)技术
    • 维护窗口和 s u m sum sum,当 s u m ≥ x sum \geq x sumx 时统计有效区间数
  3. 算法流程

    1. 初始化指针 l e f t = 0 left=0 left=0,窗口和 s u m = 0 sum=0 sum=0,计数器 c o u n t = 0 count=0 count=0
    2. 遍历数组,右指针 r i g h t right right 0 0 0 N − 1 N-1 N1
      • a [ r i g h t ] a[right] a[right] 加入 s u m sum sum
      • s u m ≥ x sum \geq x sumx 时:
        • 所有以 r i g h t right right 结尾的子数组 [ l , r i g h t ] [l,right] [l,right] l ≤ l e f t l \leq left lleft)都满足条件
        • 增加计数 c o u n t ← c o u n t + ( N − r i g h t ) count \leftarrow count + (N - right) countcount+(Nright)
        • 移动左指针缩小窗口: s u m ← s u m − a [ l e f t ] , l e f t ← l e f t + 1 sum \leftarrow sum - a[left], left \leftarrow left+1 sumsuma[left],leftleft+1

代码实现

Java
import java.util.Scanner;// 博主亲测版
public class 寻找连续区间 {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int len = scanner.nextInt();int target = scanner.nextInt();int[] arr = new int[len];for (int i = 0; i < len; i++) {arr[i] = scanner.nextInt();}int sum = 0;int tempSum;int count = 0;for (int right = 0; right < len; right++) {sum += arr[right];tempSum = sum;for (int left = 0; left <= right; left++) {if (tempSum >= target) {tempSum -= arr[left];count++;}}}System.out.println(count);}
}
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int N = sc.nextInt();int x = sc.nextInt();int[] a = new int[N];for (int i = 0; i < N; i++) a[i] = sc.nextInt();int count = 0, left = 0, sum = 0;for (int right = 0; right < N; right++) {sum += a[right];while (sum >= x) {count += N - right;sum -= a[left++];}}System.out.println(count);}
}
Python
n, x = map(int, input().split())
a = list(map(int, input().split()))count = left = current_sum = 0
for right in range(n):current_sum += a[right]while current_sum >= x:count += n - rightcurrent_sum -= a[left]left += 1print(count)
C++
#include <iostream>
#include <vector>
using namespace std;int main() {int N, x;cin >> N >> x;vector<int> a(N);for (int i = 0; i < N; i++) cin >> a[i];int count = 0, left = 0, sum = 0;for (int right = 0; right < N; right++) {sum += a[right];while (sum >= x) {count += N - right;sum -= a[left++];}}cout << count << endl;return 0;
}
JavaScript
const readline = require('readline');
const rl = readline.createInterface({input: process.stdin,output: process.stdout
});let input = [];
rl.on('line', line => {input.push(line);
}).on('close', () => {const [N, x] = input[0].split(' ').map(Number);const a = input[1].split(' ').map(Number);let count = 0, left = 0, sum = 0;for (let right = 0; right < N; right++) {sum += a[right];while (sum >= x) {count += N - right;sum -= a[left++];}}console.log(count);
});

复杂度分析

  • 时间复杂度 O ( N ) O(N) O(N)
    每个元素最多被访问两次(右指针和左指针各一次)
  • 空间复杂度 O ( 1 ) O(1) O(1)
    仅使用常数个额外变量

测试用例

测试用例 1
输入:

5 10
1 2 3 4 5

输出:

9

解释:
满足条件的子数组:
[ 1 , 2 , 3 , 4 ] [1,2,3,4] [1,2,3,4], [ 1 , 2 , 3 , 4 , 5 ] [1,2,3,4,5] [1,2,3,4,5],
[ 2 , 3 , 4 ] [2,3,4] [2,3,4], [ 2 , 3 , 4 , 5 ] [2,3,4,5] [2,3,4,5],
[ 3 , 4 , 5 ] [3,4,5] [3,4,5], [ 4 , 5 ] [4,5] [4,5], [ 5 ] [5] [5]

测试用例 2
输入:

1 100
50

输出:

0

测试用例 3
输入:

4 5
5 1 1 5

输出:

6

问题总结

  1. 关键点

    • 利用滑动窗口维护当前子数组和
    • 当和满足条件时,快速计算以当前右指针结尾的有效子数组数
  2. 算法选择

    • 滑动窗口适用于正数数组的区间和问题
    • 保证线性时间复杂度,适合大规模数据
  3. 扩展思考

    • 如果包含负数,需要改用前缀和+二分查找
    • 类似问题:求满足 ∑ ≤ x \sum \leq x x 的子数组数

文章转载自:

http://EReVQ2gY.qdcpn.cn
http://l5niSyf2.qdcpn.cn
http://acK1uyQl.qdcpn.cn
http://2E9n5NSQ.qdcpn.cn
http://OCYigo4x.qdcpn.cn
http://6HfKtxeN.qdcpn.cn
http://ZuLn4rLO.qdcpn.cn
http://ZsG5m8yb.qdcpn.cn
http://chUu3iPP.qdcpn.cn
http://JXtMGmTa.qdcpn.cn
http://UfbLO9y0.qdcpn.cn
http://qwcKDpVz.qdcpn.cn
http://loNUITXJ.qdcpn.cn
http://IHChHfTo.qdcpn.cn
http://5ouTDRzX.qdcpn.cn
http://bJAVeYOG.qdcpn.cn
http://fxU8OJm1.qdcpn.cn
http://Yr3BpBbg.qdcpn.cn
http://TrpIvOBR.qdcpn.cn
http://0GHpI8Nd.qdcpn.cn
http://nvfLdjSK.qdcpn.cn
http://bxnAKVNV.qdcpn.cn
http://XFMf3ArQ.qdcpn.cn
http://hhJWeuxR.qdcpn.cn
http://eDK2YuHa.qdcpn.cn
http://qBbISu5n.qdcpn.cn
http://cvCagmWw.qdcpn.cn
http://T3kv2V6t.qdcpn.cn
http://3tukoZRE.qdcpn.cn
http://8GZZ0slG.qdcpn.cn
http://www.dtcms.com/wzjs/710251.html

相关文章:

  • 网站系统怎么用建设一个大型网站需要多少钱
  • 山东网络推广网站网站手机端做排名
  • wordpress 404跳转企业网站的搜索引擎推广与优化
  • 做公司网站需要哪些资料青海个人旅游网站建设
  • 上海市官方网站招聘网站开发计划
  • 个人网站建设一般流程商务网站建设怎样收费
  • 做海报的网站有哪些内容网站开发维护合同样板
  • 温州专业手机网站制作哪家便宜网站建设企业有哪些内容
  • 网站开发视频播放网站集团公司管理系统
  • ps做网站导航条网站内链检测
  • 国外文件传输网站php python WordPress
  • 建设部网站资质查询制造业网站建设
  • 云南九泰建设工程有限公司官方网站杭州有哪些软件公司
  • 石家庄网站建设seo公司咨询公司注册经营范围
  • 个人网站首页个人怎么样做网站
  • 深圳企业网站建设方案如何建设盈利网站
  • 动易的网站系统软件开发者怎么赚钱
  • 什么专业可以做网站编辑软件开发文档的作用
  • 建设网站是否等于开展网络营销做seo推广一年大概的费用
  • 西宁整站优化做网站体会
  • 大连做网站外包网站搭建接单
  • 2016网站建设总结网站建设培训机构
  • 网页设计免费网站推荐设备网站开发
  • 山东建设监理协会继续教育网站河南金建建设集团网站
  • 建设网站课程设计摘要效果图网站排行
  • 做类似淘宝一样的网站有哪些石家庄做网站推广排名的公司
  • 设计师做帆布包网站定制网站建设加盟代理
  • 企业网站诊断做视频链接的网站吗
  • 广东建设报网站莲湖微网站建设
  • 太原网站建设外包价格网页设计的基本结构