博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Bzoj 2789: [Poi2012]Letters 树状数组,逆序对
阅读量:5753 次
发布时间:2019-06-18

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

2789: [Poi2012]Letters

Time Limit: 20 Sec  Memory Limit: 128 MB
Submit: 278  Solved: 185
[][][]

Description

给出两个长度相同且由大写英文字母组成的字符串A、B,保证A和B中每种字母出现的次数相同。

现在每次可以交换A中相邻两个字符,求最少需要交换多少次可以使得A变成B。

 

Input

 

 

第一行一个正整数n (2<=n<=1,000,000),表示字符串的长度。

第二行和第三行各一个长度为n的字符串,并且只包含大写英文字母。

 

 

Output

一个非负整数,表示最少的交换次数。

Sample Input

3
ABC
BCA

Sample Output

2

HINT

 

 

 
ABC -> BAC -> BCA
 

 

Source

 

题解:

树状数组+逆序对

口胡 :Bzoj好像挂了QAQ,好伤心555555

好了,开始说正题。

首先,最少次数交换相邻的元素之类的肯定用树状数组求逆序对。然后考虑贪心。

这道题的贪心思路很好想,就是把B数列每个数把其在A数列中最近的数移过来。

例如:

A数列 : ABACA

B数列 : ABCAA

对于B数列中每个数,我们去找在A数列中应该出现的位置,若字母相同就往后找,直到找到第一个没有在A数列中选过的位置。

则上述例子可以得到数列:1 2 4 3 5

然后逆序对胡搞。。。

具体看程序,自己手推一下就懂了 ^w^

PS:把int变量定到char类型中也是爽。。。QAQ

1 #include
2 #include
3 #include
4 #include
5 #include
6 #include
7 using namespace std; 8 #define LL long long 9 #define MAXN 100001010 struct node11 {12 int v,w;13 }a[MAXN],b[MAXN];14 /*struct NODE15 {16 int v,w;17 }b[MAXN];*/18 int n;19 int BIT[MAXN],c[MAXN];20 char A[MAXN],B[MAXN];21 bool cmp(node aa,node bb)22 {23 if(aa.v==bb.v)return aa.w
0)44 {45 sum+=BIT[o];46 o-=Lowbit(o);47 }48 return sum;49 }50 int main()51 {52 int i;53 LL ans=0;54 scanf("%d",&n);55 scanf("\n%s\n%s",A+1,B+1);56 for(i=1;i<=n;i++)57 {58 a[i].v=A[i]-'A'+1;b[i].v=B[i]-'A'+1;59 a[i].w=b[i].w=i;60 }61 sort(a+1,a+n+1,cmp);62 sort(b+1,b+n+1,cmp);63 for(i=1;i<=n;i++)c[a[i].w]=b[i].w;64 memset(BIT,0,sizeof(BIT));ans=0;65 for(i=n;i>=1;i--)66 {67 ans+=Sum(c[i]-1);68 Update(c[i],1);69 }70 printf("%lld",ans);71 fclose(stdin);72 fclose(stdout);73 return 0;74 }

 

转载于:https://www.cnblogs.com/Var123/p/5339336.html

你可能感兴趣的文章
Django_4_视图
查看>>
Linux的netstat命令使用
查看>>
IntelliJ IDEA 连接数据库详细过程
查看>>
android学习笔记——onSaveInstanceState的使用
查看>>
工作中如何做好技术积累
查看>>
apache安装报错undefined reference ssl
查看>>
关于爱情只有一句忠告
查看>>
F#初学笔记06
查看>>
实战:将企业域名解析委派给企业DNS服务器
查看>>
在Lync 2013环境部署Office Web Apps
查看>>
微软大会Ignite,你准备好了么?
查看>>
读书笔记-高标管事 低调管人
查看>>
Master带给世界的思考:是“失控”还是进化
查看>>
用户和开发者不满苹果iCloud问题多多
查看>>
java.lang.UnsatisfiedLinkError:no dll in java.library.path终极解决之道
查看>>
我的工具:文本转音频文件
查看>>
【许晓笛】从零开始运行EOS系统
查看>>
【跃迁之路】【460天】程序员高效学习方法论探索系列(实验阶段217-2018.05.11)...
查看>>
C++入门读物推荐
查看>>
TiDB 源码阅读系列文章(七)基于规则的优化
查看>>