ACM集训日记-8月21日

    转眼间,暑期集训到了末尾,这几天一直在看博客,看得很慢,吸收的很慢,树状数组真的很难想,光看题目意思没办法联想到用树状数组去解决,比如今天看的这道题,给你一个n个整数组成的序列,每次只能交换相邻的两个元素,问你最少要进行多少次交换才能使得整个整数序列上升有序。这里需要用到数学学的逆序数,然后就不知道怎么去下手了,解决的妙办法:处理第i个数a[i]的时候,它的逆序为:x[max]+x[max-1]+…+x[a[i]+1]的值( 即为sum(max)-(x[0]+x[1]+…+x[a[i]-1]) ),且我们需要令x[a[i]]++。x[v]=1表示在之前的扫描已经有v的数被扫描了,然后就可以算出逆序数ans。还有个新的词汇,就是离散化,要用到离散化的地方就是当以权值为下标的时候,值太大,数组开不了这么大。 然后把要离散化的每一个数组里面的数映射到另一个值小一点的数组里面去,因为在那个值小一点的数组里本来是没有东西的。

    看了好才明白,自己又照着题解重新敲了一遍代码,缓缓的理解。有时候看着题解的思路顺着敲也有助于理解。

    明天加油,坚持到最后一天!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值