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

网站底部图片代码推广网站的广告怎样做

网站底部图片代码,推广网站的广告怎样做,个体工商户备案网站备案,杭州网站建设公司联系方式题目描述 静态扫描可以快速识别源代码的缺陷,静态扫描的结果以扫描报告作为输出: 1、文件扫描的成本和文件大小相关,如果文件大小为N,则扫描成本为N个金币 2、扫描报告的缓存成本和文件大小无关,每缓存一个报告需要…

题目描述

静态扫描可以快速识别源代码的缺陷,静态扫描的结果以扫描报告作为输出:

1、文件扫描的成本和文件大小相关,如果文件大小为N,则扫描成本为N个金币

2、扫描报告的缓存成本和文件大小无关,每缓存一个报告需要M个金币

3、扫描报告缓存后,后继再碰到该文件则不需要扫描成本,直接获取缓存结果

给出源代码文件标识序列和文件大小序列,求解采用合理的缓存策略,最少需要的金币数。

输入描述
第一行为缓存一个报告金币数M,L<= M <= 100

第二行为文件标识序列:F1,F2,F3,…,Fn。

第三行为文件大小序列:S1,S2,S3,…,Sn。

备注:

1 <= N <= 10000
1 <= Fi <= 1000
1 <= Si <= 10

输出描述
采用合理的缓存策略,需要的最少金币数

用例

输入5
1 2 2 1 2 3 4
1 1 1 1 1 1 1
输出7
说明文件大小相同,扫描成本均为1个金币。缓存任意文件均不合算,因而最少成本为7金币。
输入5
2 2 2 2 2 5 2 2 2
3 3 3 3 3 1 3 3 3
输出9
说明

静态扫描成本优化:缓存策略的贪心解法

核心解题思路

题目要求通过合理的缓存策略最小化静态扫描的总成本,核心问题是:对于重复出现的文件,何时缓存报告最划算? 关键在于权衡扫描成本与缓存成本:

  • 扫描成本:每次扫描文件需支付其大小的金币(文件越大成本越高)
  • 缓存成本:缓存报告需固定支付M金币(后续相同文件可免扫描)
  • 决策关键:对每个文件标识,判断"缓存并复用"还是"每次重新扫描"更经济

贪心策略

对每个文件标识独立决策:

  • 若不缓存:总成本 = 文件大小 × 出现次数
  • 若缓存:总成本 = 第一次扫描成本 + 缓存成本
  • 选择成本更低的方案min(文件大小×频次, 文件大小 + M)

为什么贪心有效?每个文件的缓存决策相互独立,缓存一个文件不会影响其他文件的扫描成本。

解题步骤详解

1. 输入处理与参数设置

# 读取缓存成本M
M = int(input().strip())# 读取文件标识序列
file_ids = list(map(int, input().split()))# 读取文件大小序列
file_sizes = list(map(int, input().split()))

2. 构建文件分组统计

from collections import defaultdict# 创建分组字典:记录每个标识的[频次, 总大小, 首次大小]
file_groups = defaultdict(lambda: [0, 0, None])# 遍历所有文件
for fid, size in zip(file_ids, file_sizes):# 更新出现频次file_groups[fid][0] += 1# 累加总大小(用于不缓存方案)file_groups[fid][1] += size# 记录首次出现的大小(用于缓存方案)if file_groups[fid][2] is None:file_groups[fid][2] = size

3. 计算最小成本

total_cost = 0
for fid, (count, total_size, first_size) in file_groups.items():# 不缓存方案:每次扫描cost_no_cache = total_size# 缓存方案:首次扫描+缓存cost_cache = first_size + M# 选择更经济的方案total_cost += min(cost_no_cache, cost_cache)

4. 输出结果

print(total_cost)

关键逻辑解析

1. 分组统计的重要性

  • 频次(count):决定重复扫描的成本
  • 总大小(total_size):计算不缓存方案的总成本
  • 首次大小(first_size):缓存方案只需首次扫描成本

为何记录首次大小而非任意大小?
缓存发生在首次扫描时,后续文件无论大小如何都复用结果

2. 成本比较的数学原理

决策依据的数学表达式:
min( Σsᵢ , s₁ + M )
其中:

  • Σsᵢ:所有出现位置的大小之和
  • s₁:首次出现的大小
  • M:固定缓存成本

3. 独立决策的正确性

  • 文件标识相互独立,缓存决策无耦合
  • 缓存文件A不影响文件B的扫描
  • 局部最优解之和等于全局最优解

完整代码实现

from collections import defaultdictdef main():# 读取缓存成本M = int(input().strip())# 读取文件标识序列file_ids = list(map(int, input().split()))# 读取文件大小序列file_sizes = list(map(int, input().split()))# 创建分组统计字典# 格式: {文件标识: [出现次数, 总大小, 首次大小]}file_groups = defaultdict(lambda: [0, 0, None])# 遍历所有文件for fid, size in zip(file_ids, file_sizes):# 更新出现次数file_groups[fid][0] += 1# 累加总大小file_groups[fid][1] += size# 记录首次大小if file_groups[fid][2] is None:file_groups[fid][2] = size# 计算最小总成本total_cost = 0for fid, (count, total_size, first_size) in file_groups.items():# 计算两种方案成本cost_no_cache = total_sizecost_cache = first_size + M# 选择更经济的方案total_cost += min(cost_no_cache, cost_cache)print(total_cost)if __name__ == "__main__":main()

复杂度分析

  • 时间复杂度:O(N)
    • 遍历文件序列:O(N)
    • 分组统计:O(N)
    • 决策计算:O(K)(K为唯一文件数,K ≤ N)
  • 空间复杂度:O(K)
    • 存储分组信息:O(K)(K为唯一文件标识数)

示例验证

示例1:

输入:

5
1 2 2 1 2 3 4
1 1 1 1 1 1 1

处理流程:

  1. 分组统计:
    • 文件1: [频次=2, 总大小=2, 首次大小=1]
    • 文件2: [频次=3, 总大小=3, 首次大小=1]
    • 文件3: [频次=1, 总大小=1, 首次大小=1]
    • 文件4: [频次=1, 总大小=1, 首次大小=1]
  2. 成本决策:
    • 文件1: min(2, 1+5)=2
    • 文件2: min(3, 1+5)=3
    • 文件3: min(1, 1+5)=1
    • 文件4: min(1, 1+5)=1
  3. 总成本:2+3+1+1=7
    输出:7

示例2:

输入:

5
2 2 2 2 2 5 2 2 2
3 3 3 3 3 1 3 3 3

处理流程:

  1. 分组统计:
    • 文件2: [频次=8, 总大小=24, 首次大小=3]
    • 文件5: [频次=1, 总大小=1, 首次大小=1]
  2. 成本决策:
    • 文件2: min(24, 3+5)=8
    • 文件5: min(1, 1+5)=1
  3. 总成本:8+1=9
    输出:9

总结

通过贪心策略解决静态扫描成本优化问题:

  1. 问题特性:重复文件可复用缓存,决策相互独立
  2. 核心洞察:缓存的价值 = 后续扫描成本节省 - 缓存成本
  3. 算法选择:分组统计 + 成本比较(O(N)时间复杂度)
  4. 优化关键
    • 小文件高频:倾向不缓存(如示例1)
    • 大文件高频:倾向缓存(如示例2)
    • 低频文件:通常不缓存

实际应用场景:编译器构建系统(如Makefile)、CI/CD流水线,通过缓存中间结果加速重复构建过程。


文章转载自:

http://mx3HdPlR.fLhkL.cn
http://q4vQA6ak.fLhkL.cn
http://P75NPz0A.fLhkL.cn
http://VIqjjXXp.fLhkL.cn
http://X0ONh651.fLhkL.cn
http://QTU7JhK1.fLhkL.cn
http://Lsz6FgTY.fLhkL.cn
http://eENwkNJz.fLhkL.cn
http://z7cMY1vt.fLhkL.cn
http://gsbyJJl7.fLhkL.cn
http://1x9QRhtn.fLhkL.cn
http://sxuXgIip.fLhkL.cn
http://necOVXi8.fLhkL.cn
http://M4AGR5ss.fLhkL.cn
http://oyA9WjAV.fLhkL.cn
http://A1NsCsqs.fLhkL.cn
http://xPBj7eYn.fLhkL.cn
http://BfwDHSN5.fLhkL.cn
http://uu4X1tbg.fLhkL.cn
http://nlA788hf.fLhkL.cn
http://vZuvFrfR.fLhkL.cn
http://Fa9985ev.fLhkL.cn
http://h2mbcaq5.fLhkL.cn
http://Ahk1vD70.fLhkL.cn
http://B19lNnco.fLhkL.cn
http://XKvuKX7e.fLhkL.cn
http://tiqhAZ7X.fLhkL.cn
http://mVTL8PIo.fLhkL.cn
http://dhfeFyL7.fLhkL.cn
http://8Y0gqYXd.fLhkL.cn
http://www.dtcms.com/wzjs/742424.html

相关文章:

  • 顺德定制网站设计关键词搜索量查询
  • 外贸购物网站开发深圳微信分销网站设计
  • 客户做网站嫌贵了色母粒
  • 网站建设实训课做网站的费用入账
  • 怎呀做网站婚庆影楼型网站开发
  • 青岛工程建设监理公司网站网络营销常用的方法有哪些
  • 布吉网站建设哪家效益快网站站制做
  • 二十一冶建设有限公司网站最新的网络营销的案例
  • 如何搭建网站的支付接口沐风+wordpress+主题
  • 外贸网站推广渠道建设网站需要了解些什么问题
  • 网站下载软件入口网站后台乱码怎么办
  • 网站搜索功能设计网站运营招聘要求
  • 昆山张浦做网站wordpress 景点模板
  • 高安市网站建设公司10元云服务器
  • 做网咖的网站app开发制作
  • 网页设计网站模板素材现代企业信息管理系统
  • 卫浴洁具网站模板宣传册设计与制作合同
  • 多语言网站建设费用代理备案网站
  • 北京网站制作公司哪家好中国网新重庆
  • 网站诚信备案网站建设 漳州
  • 网站源码怎么使用宁波建设集团几个分公司
  • 整个网站开发框架流程咸阳网站设计建设公司
  • 试玩网站建设微信朋友圈推广
  • 高端集团官方网站建设公司更改wordpress登陆界面
  • 什么网站是solr做的久久建筑网怎么不好用
  • 网站做好了怎么做后台管理新会住房和城乡建设部网站
  • 网站标准尺寸怎么自己做一个小程序
  • 网站建设的步骤教程视频教程企业服务类型有哪些
  • 网站前台模板 html引流用什么话术更吸引人
  • 广西新农村建设工作专题网站网站数据库地址是什么