TCS_CODEVITA_QUESTION(需要解决方案)
今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《TCS_CODEVITA_QUESTION(需要解决方案)》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!
邮政总局的包裹区一片狼藉。 需要装载到货车上的包裹已按任意重量顺序排成一排。 邮政总站管理员希望按照包裹重量的升序对它们进行分类,但有一个例外。 他希望将最重(也可能是最有价值)的包裹放在离他办公室最近的地方。
问题描述
邮政总局的包裹区一片狼藉。 需要装载到货车上的包裹已按任意重量顺序排成一排。 邮政总站管理员希望按照包裹重量的升序对它们进行分类,但有一个例外。 他希望将最重(也可能是最有价值)的包裹放在离他办公室最近的地方。
您和您的朋友尝试对这些盒子进行排序,并且您决定通过一次交换两个盒子来对它们进行排序。 这样的交换需要的努力等于两个盒子重量的乘积。
目标是以最小的努力根据需要重新定位盒子。
输入
第一行由两个空格分隔的正整数组成,给出箱子的数量 (N) 以及最重箱子所在的邮政局长办公室的位置 (k)。
第二行由 N 个空格分隔的正整数组成,给出了框的权重。 您可以假设没有两个权重是相等的。
输出
输出一行给出了按排序顺序排列盒子所需的总工作量,以及最重的位置 k。
限制
n<=50
权重 <= 1000
难度等级
复杂
时间限制(秒)
1
示例
示例1
输入
5 2
20 50 30 80 70
输出
3600
说明
有 5 个盒子 (N=5),最重的盒子必须位于位置 2 (k=2)。 如果我们看一下最终的订单(已排序,最重的在位置 2),它应该是 20 80 30 50 70。如果我们看一下这个,我们注意到只有 50 和 80 包裹需要交换。 由于这需要权重乘积的努力,因此努力为 4000。
如果我们使用最小的包(20)作为中介,可以获得进一步的减少。 如果我们用50(努力1000)交换20,然后用80(努力1600)交换,再用50(努力1000)交换,效果是一样的,总努力为3600(小于直接获得的努力)移动)和努力
最优交换顺序后的结果是
50 20 30 80 70
50 80 30 20 70
20 80 30 80 70
由于这需要 3600 的努力,因此输出为 3600。
示例2
输入
6 3
30 20 40 80 70 60
输出
7600
说明
有6个包裹,最重的应该在位置3。因此最终订单需要是20 30 80 40 60 70。如果我们看初始位置,我们发现20和30需要交换(努力600),40和80需要交换(努力3200),60和70需要交换(努力4200)。 因此总的努力是600+3200+4200=8000。
如果我们使用与示例 1 相同的方法,我们会得到以下成果
(600) 20 30 40 80 70 60
(3200) 20 30 80 40 70 60
(1200) 60 30 80 40 70 20
(1400) 60 30 80 40 20 70
(1200) 20 30 80 40 60 70
总共获得了 7600 的努力,而不是 8000 的努力,这是输出。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

- 上一篇
- 如何在 Vue 中渲染带括号的文本?

- 下一篇
- 全面解析:12V电脑电源的工作原理与选购指南
-
- 文章 · java教程 | 4小时前 | eclipse 设置步骤 中文界面 IntelliJIDEA 字体显示
- Java开发工具中文界面设置教程
- 169浏览 收藏
-
- 文章 · java教程 | 5小时前 |
- Java、Python、C语言三者区别详解
- 328浏览 收藏
-
- 文章 · java教程 | 5小时前 |
- Java必备知识点详解,体系结构全解析
- 270浏览 收藏
-
- 文章 · java教程 | 11小时前 |
- HBase配置文件测试及Kerberos认证连接问题解决
- 351浏览 收藏
-
- 文章 · java教程 | 15小时前 |
- 学Java必备知识点全解析,Java体系详解
- 133浏览 收藏
-
- 文章 · java教程 | 1天前 |
- 反序输出字符串:填码验证算法小练习
- 278浏览 收藏
-
- 文章 · java教程 | 1天前 |
- Java非C语言开发,揭秘Java技术实现
- 236浏览 收藏
-
- 文章 · java教程 | 2天前 |
- Java学习必备知识体系结构详解
- 237浏览 收藏
-
- 文章 · java教程 | 2天前 |
- 若依框架MyBatis依赖配置及查找方法
- 194浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 协启动
- SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
- 7次使用
-
- Brev AI
- 探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
- 7次使用
-
- AI音乐实验室
- AI音乐实验室(https://www.aimusiclab.cn/)是一款专注于AI音乐创作的平台,提供从作曲到分轨的全流程工具,降低音乐创作门槛。免费与付费结合,适用于音乐爱好者、独立音乐人及内容创作者,助力提升创作效率。
- 6次使用
-
- PixPro
- SEO摘要PixPro是一款专注于网页端AI图像处理的平台,提供高效、多功能的图像处理解决方案。通过AI擦除、扩图、抠图、裁切和压缩等功能,PixPro帮助开发者和企业实现“上传即处理”的智能化升级,适用于电商、社交媒体等高频图像处理场景。了解更多PixPro的核心功能和应用案例,提升您的图像处理效率。
- 6次使用
-
- EasyMusic
- EasyMusic.ai是一款面向全场景音乐创作需求的AI音乐生成平台,提供“零门槛创作 专业级输出”的服务。无论你是内容创作者、音乐人、游戏开发者还是教育工作者,都能通过EasyMusic.ai快速生成高品质音乐,满足短视频、游戏、广告、教育等多元需求。平台支持一键生成与深度定制,积累了超10万创作者,生成超100万首音乐作品,用户满意度达99%。
- 9次使用
-
- 提升Java功能开发效率的有力工具:微服务架构
- 2023-10-06 501浏览
-
- 掌握Java海康SDK二次开发的必备技巧
- 2023-10-01 501浏览
-
- 如何使用java实现桶排序算法
- 2023-10-03 501浏览
-
- Java开发实战经验:如何优化开发逻辑
- 2023-10-31 501浏览
-
- 如何使用Java中的Math.max()方法比较两个数的大小?
- 2023-11-18 501浏览