博客
关于我
2018HDU多校2-1010-Swaps and Inversions(hdu 6318)-逆序数,树状数组
阅读量:281 次
发布时间:2019-03-01

本文共 295 字,大约阅读时间需要 1 分钟。

数列处理问题:最小花费计算方法

在处理数列时,可以选择两种方式:每次交换相邻元素花费y元,或者处理每个逆序数花费x元。目标是找到最小的总花费。

关键思路是分析交换次数对逆序数的影响。交换一次相邻元素最多只能减少一个逆序数,因此可能存在两种情况:全部交换或不交换。这种情况下,只需计算逆序数总数即可决定选择哪种方式。

使用树状数组高效计算逆序数。将数列从大到小排序,记录每个数出现的位置。每次选最大数,若前面有其他数,则有逆序数。累加这些逆序数得到总数。

代码实现了这一思路,计算逆序数后,比较两种花费方式,取较小值输出。

改进空间包括更复杂的交换策略,但目前的方法在时间复杂度上已足够高效。

转载地址:http://daco.baihongyu.com/

你可能感兴趣的文章
php PSR规范
查看>>
php rand() 重复,array_rand()函数从另外一个数组中随机取得的一定数量的数组的元素是否会重复?...
查看>>
php redis pub/sub(Publish/Subscribe,发布/订阅的信息系统)之基本使用
查看>>
php redis 集群扩展类文件
查看>>
php redis(2)
查看>>
PHP Redis分布式锁
查看>>
php session超时时间_php怎么设置session超时时间
查看>>
PHP SOAP模块的使用方法:NON-WSDL模式
查看>>
php Socket通信
查看>>
PHP SPL标准库-迭代器
查看>>
PHP Static延迟静态绑定
查看>>
PHP study 环境变量composer
查看>>
php unicode编码转成unioce字符(中文)
查看>>
PHP XSS攻击防范--如何过滤用户输入
查看>>
php zookeeper实现分布式锁
查看>>
PHP 中 this,self,parent 的区别、用法
查看>>
PHP 中如何高效地处理大规模数据的排序?
查看>>
PHP 使用 $_SERVER['PHP_SELF'] 获取当前页面地址及其安全性问题
查看>>
PHP 函数名前面加&
查看>>
php 反射
查看>>