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

滕州做网站品牌网络营销策划

滕州做网站,品牌网络营销策划,北京环保网站建设,建个网站的流程一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 Problem - 1954D - Codeforces 二、解题报告 1、思路分析 本题前置题目: 1953. 你可以工作的最大周数 通过前置题目可以知道如何计算两两不同数对序列的最大长度 我们记最大数量为ma&#xf…

一、题目

1、题目描述

2、输入输出

2.1输入

2.2输出

3、原题链接

Problem - 1954D - Codeforces


二、解题报告

1、思路分析

本题前置题目:

1953. 你可以工作的最大周数

通过前置题目可以知道如何计算两两不同数对序列的最大长度

我们记最大数量为ma,总数目为N

如果ma > N / 2, 那么划分的组数取决于ma,即ma组

如果ma <= N / 2, 那么划分组数为floor(N / 2)

换句话说,任意(N, ma)我们可以计算出其组数

那么(N, ma)状态有多少种?每种(n,ma)有多少个?

n个颜色最多对应n个ma,也就是说我们最多有N * n种状态

而N 和 n的上界都是5000

我们如果定义状态f[总数][最大值],那么每次状态转移需要遍历比当前最大值小的状态,这样的时间复杂度为O(n^3)

但是我们发现我们将原数组排序,那么我们顺序遍历的时候,最大值就是当前值

我们考虑设计状态f[i][x]为遍历到第i个物品时,容量为x的方案数

那么f[i][x] = Σf[i -1][j - nums[i]]

而我们得知方案数后自然可以根据容量和当前最大值nums[i]来计算其贡献

然后我们用f[i][x]更新f[i + 1][x + nums[i]]即可

我们发现这似乎退化成了01背包问题,而且可以滚动数组优化

然后问题就迎刃而解了

2、复杂度

时间复杂度: O(n^2)空间复杂度:O(n)

3、代码详解

# import sys# sys.stdin = open('in.txt','r')
mod = 998244353n = int(input())
a = list(map(int, input().split()))a.sort()f = [0] * 5001
f[0] = 1res = s = 0
for x in a:for i in range(s, -1, -1):if f[i]:res = (res + f[i] * max((i + x + 1) // 2, x)) % modf[i + x] = (f[i] + f[i + x ]) % mods += xprint(res)

http://www.khdw.cn/news/50045.html

相关文章:

  • 阿里巴巴国际站入驻费用最新军事动态最新消息
  • 微企点建站怎么样优化疫情防控措施
  • 网站微信推广怎么做台州seo
  • 上海网站的优化公司怎么进入百度推广账户
  • 微信小程序开发技术介绍宁波网站优化公司推荐
  • 表格比较多得网站这么做响应式免费收录网站
  • 做网站推广的一般都是什么公司做seo排名好的公司
  • 海报字体手绘转换器搜索引擎seo是什么意思
  • 合肥 做网站中山网站seo优化
  • 小程序代理商怎么赚钱成都最好的seo外包
  • 淘客网站让别人做免费网络推广
  • 制作精美网站建设口碑好网页制作平台有哪些
  • 把网站内容全删掉 在重新建立会不会被k百度电脑版官网下载
  • 做seo网站诊断书怎么做免费seo技术教程
  • asp.net网站开发论文手机建站教程
  • 免费的网站域名查询浏览器网站优化推广方案
  • 企业信息填报系统搜索引擎优化的方法
  • 公众平台的微信网站开发seo推广教学
  • 制作网站的布局网络网站黄页推广软件
  • 长春作网站深圳专业seo外包
  • 手机网站建设机构杭州今天查出多少阳性
  • 色情网站 后缀gr百度网站提交
  • 做网站怎么赚钱 注册推广软文范文800字
  • 乌鲁木齐建设网站公司域名被墙检测
  • 贵州省网站节约化建设通知品牌策划方案怎么做
  • 视频网站开发步骤seo工资服务
  • 县政府网站问题建设调研报告线上营销怎么做
  • 海口h5建站百度关键词排名代做
  • 用织梦网站后台发布文章为什么还需要审核今日头条新闻视频
  • 物流推广做哪个网站百度网站ip地址