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

软件公司排名国内青岛seo杭州厂商

软件公司排名国内,青岛seo杭州厂商,开发公司房屋委托中介出售协议,福鼎网站开发目录 区间价值 题目描述 输入描述: 输出描述: 输入 输出 备注: 思路: 代码: 区间价值 J-区间价值_牛客竞赛动态规划专题班习题课 (nowcoder.com) 时间限制:C/C 2秒,其他语言4秒 空间限制:C/C 262144K&…

目录

区间价值

题目描述

输入描述:

输出描述:

输入

输出

备注:

思路:

代码:


 

区间价值

J-区间价值_牛客竞赛动态规划专题班习题课 (nowcoder.com)
 

时间限制:C/C++ 2秒,其他语言4秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld

题目描述

对于一个数组a,定义其价值是其中不同的数的个数,比如对于数组[3,2,2,3,1],价值就是3。对于一个给定的长度len,求出所有长度为lenlenlen的子区间的价值之和是对于吉吉国王来说很重要,现在吉吉国王会告诉你他想知道的长度lenlenlen,你需要告诉吉吉国王答案。

比如数组[3,2,2,3,1],长度为2的子区间有[3,2],[2,2],[2,3],[3,1],那么价值分别是2,1,2,2,因此这个数组长度为2的价值和就是7。

输入描述:

第一行一个n表示数组的长度。

第二行n个数,第iii个数表示ai。

第三行一个q表示询问的次数。

接下来q行,每行一个整数表示查询的长度。

输出描述:

输出q行,第i行表示第i个询问的答案。

示例1

输入

5
3 2 4 3 1
4
1
2
3
4

输出

5
8
9
7

备注:

1≤n≤1e6 

思路:

这道题容易想到的是暴力解法(区间dp)但这肯定是会爆时间的。

现在设dp[i] 表示区间为i时的价值和。

那怎么从dp[i-1] 转移到 dp[i]

假如 当前区间为3, 数组为 32441

324 -> 3244 贡献不变

244 -> 2441 贡献加1

441 -> null 贡献-2

这里可以看出从dp[i-1] 到 dp[i] 会损伤掉后面 i-1个数的贡献值,并且前几个区间有s[i]的贡献增加。

前几个区间中那些区间是会提供贡献,或者说那些数在区间变大时可以提供贡献,这是可以预处理出来的,因为可以观察发现只有两个相同数的相隔距离大于等于i时,他们才会在长度为i的区间中提供一个贡献。(这里需要用一个后缀和统计)

代码:

import java.util.Scanner;/*** @ProjectName: study3* @FileName: Ex7* @author:HWJ* @Data: 2023/12/5 19:53*/
public class Main {static int maxN = (int) 1e6 + 5;public static void main(String[] args) {Scanner input = new Scanner(System.in);int n = input.nextInt();int[] arr = new int[maxN];int[] last = new int[maxN];long[] s = new long[maxN];int[] diff = new int[maxN];int[] cnt = new int[maxN];for (int i = 1; i <= n; i++) {arr[i] = input.nextInt();s[i - last[arr[i]]]++;last[arr[i]] = i;}for(int i = n; i > 0; i--){s[i] = s[i] + s[i + 1];}int tot = 0;for(int i = n; i > 0; i--){if (++cnt[arr[i]] == 1) tot++;diff[n - i + 1] = tot;}long[] ans = new long[n + 1];ans[1] = n;for(int i = 2; i <= n; i++){ans[i] = ans[i - 1] + s[i] - diff[i - 1];}int q = input.nextInt();for (int i = 0; i < q; i++) {int a = input.nextInt();System.out.println(ans[a]);}}
}

http://www.tj-hxxt.cn/news/82714.html

相关文章:

  • 网站设计 网络推广的服务内容小程序开发平台有哪些
  • 西安旅游攻略2天自由行攻略上海seo优化公司kinglink
  • 做暧网站免费网站页面排名优化
  • 万网域名注册商南昌seo排名外包
  • 2023年山西疫情严重吗seo创业
  • 广告设计需要学什么课程长安网站优化公司
  • 公司网站建设的建议网站关键词排名
  • 做代购注册什么网站宁波网站推广运营公司
  • 浮雕模东莞网站建设线上营销推广方案有哪些
  • 郑州专做喜宴的网站网络广告营销的案例
  • 县政府网站问题建设调研报告百度关键词搜索怎么做
  • ppt做长图网站做网站哪个公司最好
  • 盐城网站开发市场aso优化平台有哪些
  • 杭州市社区建设网站网站关键词推广工具
  • 常州百度快速优化seo在线教程
  • 需要网站建设最新社会舆情信息
  • 企业网站设计开发如何在百度发视频推广
  • 企业做网站设计百度官网认证价格
  • 坪山网站建设哪家便宜做网上营销怎样推广
  • 做网站怎么制作网站优化关键词价格
  • 做网站前怎么建立数据结构内容企业推广
  • 交警队内部网站建设拉新奖励的app排行
  • 一键搭建网站系统营销工具
  • wordpress汽配网站考研培训机构排名前五的机构
  • 邯郸市城市建设局网站济南最新消息
  • 信誉好的郑州网站建设直播网站排名
  • 政府网站集约化建设内容发布悬赏任务的推广平台
  • 阿里买域名 电脑做网站全国疫情最新消息
  • 政府网站数字化建设网络广告电话
  • 服务五象新区开发建设指挥部网站seo推广优化外包公司