CF1526 D. Kill Anton

CF1526 D. Kill Anton

题意:

给你一个由’A’,‘N’.‘T’,'O’四个字符组成的字符串b,现在要求你改变b的顺序得到a,使得a通过移动回到b的步数最多。
每次移动只能移动相邻两项

题解:

官方题解说:最佳情况为相同字符靠在一起
证明我也不清楚。。
证明可以看看这篇文章
按照官方题解的说法,将相同的字符排列在一起,一共就四种字符,那么也就是排列方式一共就24种(4!),我们直接暴力求出每种情况,然后求出其要移动的步数,取最大值
这个移动的步数咋求?
假设原先字符串是ANTON,下标依次是1,2,3,4,5,现在我们将其打乱成ATONN,原先的下标就成了1,3,4,2,5,那13425变回12345的步骤不就是其逆序对吗?所以对于每一种情况我们求其逆序对,然后保留最大值
在这里插入图片描述

这题挺好~

代码:

#include <bits/stdc++.h>
#define ll long long
using namespace std;
int a[50];//记录字符个数 
vector<int>id[50],c;//记录字符 
string s;ll nxt;
void msort(int l,int r){//归并排序 if(l>=r)return;//区间元素小于1 int mid=l+r>>1;msort(l,mid);//分 msort(mid+1,r);//分 int i=l,j=mid+1,k=0;int t[r-l+1];while(i<=mid&&j<=r){if(c[i]<=c[j])t[k++]=c[i++]; else{//此时存在逆序对,在归并过程中记录逆序对的个数 t[k++]=c[j++];nxt+=mid-i+1;//记录逆序对数 }}while(i<=mid)t[k++]=c[i++];while(j<=r)t[k++]=c[j++];for(i=l,k=0;i<=r;i++,k++)c[i]=t[k];//将t排好序的数复制到c中 
} 
int main()
{ios_base::sync_with_stdio(false);int t;cin>>t;while(t--){int r[5]={0,'A','N','O','T'};//通过函数枚举各种可能性; memset(a,0,sizeof(a));//清空 id['A'-'A'].clear();id['N'-'A'].clear();id['O'-'A'].clear();id['T'-'A'].clear();cin>>s;for(int i=0;i<s.size();i++){a[s[i]-'A']++;//记录每个字母的个数 id[s[i]-'A'].push_back(i+1); }ll ans=0;string as;do{c.clear();nxt=0;//清零记录下一种情况的操作数for(int i=1;i<=4;i++){//四个字符分别连续存入形成一个新的字符串 c.insert(c.end(),id[r[i]-'A'].begin(),id[r[i]-'A'].end());}/*cout<<"c= ";for(int i=0;i<c.size();i++)cout<<s[c[i]-1];cout<<endl; */msort(0,c.size()-1);if(nxt>ans){ans=nxt;as="";for(int i=1;i<=4;i++) as+=string(a[r[i]-'A'],(char)r[i]);//存入此时的最优字符串,即前面c的原串 }}while(next_permutation(r+1,r+5));//对四个字符全排列的各种可能性; if(ans!=0)cout<<as<<endl;else cout<<s<<endl;//ans为0说明原字符串已经为最优解 } return 0;
}

我还有看到一种写法,本质一样,它将转化后的字符串下标定为1,2,3,4…,根据这个将原字符串下标定义为nxt[j],然后跑逆序对,一样的

for(int i=0;i<len;i++){//将该情况的字符串转为数字 for(int j=0;j<=3;j++){if(mp[s[i]]==nxt[j]){//每次打乱nxt c[i]=j;break;}}}
#include<bits/stdc++.h>
#define debug(a,b) printf("%s = %d\n",a,b);
typedef long long ll;
using namespace std;
//qdu打铁匠
inline int read(){int s=0,w=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();//s=(s<<3)+(s<<1)+(ch^48);return s*w;
}
const int maxn=2e5+9;
int nxt[]={0,1,2,3};
ll a[maxn];
ll c[maxn],b[maxn];
map<char,int>mp;
ll cnt=0; 
void unite(int l,int mid,int r){if(l>=r)return ;unite(l,(l+mid)>>1,mid);unite(mid+1,(mid+1+r)>>1,r);int i=l,j=mid+1;for(ll k=l;k<=r;++k){if(j>r||i<=mid&&c[i]<=c[j]) b[k]=c[i++];else b[k]=c[j++],cnt+=mid-i+1;}for(ll k=l;k<=r;++k) c[k]=b[k]; 
}
string s;
ll cal(int len){for(int i=0;i<len;i++){//将该情况的字符串转为数字 for(int j=0;j<=3;j++){if(mp[s[i]]==nxt[j]){//每次打乱nxt c[i]=j;break;}}}cnt=0;unite(0,(len-1)>>1,len-1);//求逆序对 return cnt;
}
void solve(){cin>>s;string a,n,o,t;for(int i=0;i<s.length();i++){if(s[i]=='A')a+='A';if(s[i]=='N')n+='N'; if(s[i]=='O')o+='O';if(s[i]=='T')t+='T';}string ans=s;ll sum=0;do{ll now=cal(s.size());if(now>sum){//得到更大的逆序对,即需要步数更多 sum=now;ans.clear();for(int i=0;i<=3;i++){if(nxt[i]==0)ans+=a;if(nxt[i]==1)ans+=n;if(nxt[i]==2)ans+=t;if(nxt[i]==3)ans+=o;} }}while(next_permutation(nxt,nxt+1+3));cout<<ans<<endl;
}
int main()
{int t=read();mp['A']=0;mp['N']=1;mp['T']=2;mp['O']=3;while(t--){solve();}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/316701.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[luogu P4198] 楼房重建(线段树 + 思维)

luogu 楼房重建problemsolutioncodeproblem 洛谷链接 solution 非常巧妙的一道题&#xff0c;对线段树的运用很灵活。 显然这个与原点的连线可以想到将每个点转化为与原点连线形成的直线斜率。 答案其实就是&#xff1a;从第一个点开始选&#xff0c;后一个斜率比前面大的…

模板:P6114 【模板】Lyndon 分解Runs(字符串)

你不会连跑步都不会吧。 &#xff08;逃 前言 SAM&#xff1a;runs&#xff1f;那我run了。 比 SAM 看起来层次更高的奥妙算法。 理论证明比较复杂&#xff0c;但板子写起来都比较简单。 本文会略过很多的证明。 Lyndon 分解 Definition&#xff1a; 如果一个串本身比它的所…

ASP.NET Core 3.0预览版体验

目前.NET Core 3.0的版本为.NET Core 3.0 Preview 3&#xff0c;对应ASP.NET Core 3.0 Preview 3。ASP.NET Core 3.0 之后将不再支持.NET Framework&#xff0c;只运行在.NET Core 上面。ASP.NET Core 3.0 现在已经出到了第三个预览版&#xff0c;增加和改进了很多功能。环境准…

【无码专区13】最小公倍数(线段树)

因为只有std&#xff0c;没有自我实现&#xff0c;所以是无码专区 主要是为了训练思维能力 my idea顾名思义&#xff0c;记录了我的整个思维过程&#xff0c;以及自己部分实现细节口胡&#xff0c;还有期望分数 solution才是dls正解&#xff0c;但是因为只有潦草几句&#x…

2021牛客暑期多校训练营2

2021牛客暑期多校训练营2 题号题目知识点AArithmetic ProgressionBCannonCDraw GridsDEr Ba GameEGas StationFGirlfriendGLeague of LegendsHOlefinIPenguinsbfsJProduct of GCDsKStackLWeChat Walk

P6772 [NOI2020] 美食家(矩阵快速幂)

前言 无能狂怒。 见过甚至写过博客的trick&#xff0c;但就是想不起来了。 解析 做法1 设 ft,xf_{t,x}ft,x​ 表示 t 时刻在 x 的最大价值。 直接转移即可&#xff0c;时间复杂度 O(T(nm))O(T(nm))O(T(nm))&#xff0c;期望得分 40 分。 结合无脑转圈的 A 性质&#xff0c;…

C# .net 中 Timeout 的处理及遇到的问题

C# 中 Timeout 的处理前言最近在项目中要实现一个功能&#xff0c;是关于 Timeout 的&#xff0c;主要是要在要在 TCP 连接建立的时间 和 整个请求完成的时间&#xff0c;在这两个时间层面上&#xff0c;如果超出了设置的时间&#xff0c;就抛出异常&#xff0c;程序中断。研究…

[CodeJam 2019 Round 3] Rancake Pyramid(笛卡尔树)

CodeJam 2019 Round 3 Rancake Pyramidproblemsolutioncodeproblem 神奈子是个很爱打麻将的老婆婆&#xff0c;有一天她把她的麻将放成了 nnn 堆&#xff0c;第 iii 堆的高度为 aia_iai​ 。 因为她很喜欢风&#xff0c;所以她用风吹倒了最左边的 LLL 堆麻将和最右边的 RRR 堆…

Harbour.Space Scholarship Contest 2021-2022 (open for everyone, rated, Div. 1 + Div. 2)

Harbour.Space Scholarship Contest 2021-2022 (open for everyone, rated, Div. 1 Div. 2) 题号题目知识点ADigits Sum签到BReverse String思维CPenalty思维DBackspace逆向思维EPermutation Shift置换群FPairwise ModuloGCommon Divisor GraphHXOR and DistanceIStairs cf15…

模板:全局平衡二叉树

所谓全局平衡二叉树&#xff0c;就是在全局来看都很平衡的二叉树。 &#xff08;逃 前言 这个引言倒是实话&#xff08;雾 可以把一些本来只能用树剖两个 log 做的问题在单log 时间复杂度解决。 修改通常来说只能支持单点修改。 查询解决链上问题或者全局问题更为方便&#x…

[CodeJam 2021 Round 3] Square Free(调整法 / 字典序最小解网络流)

CodeJam 2021 Round3 Square Freeproblemsolutioncodecode-stdproblem 神奈子是个很爱打麻将的老婆婆&#xff0c;有一天她把她的麻将放进了一个 nmn\times mnm 的网格图里&#xff0c;每个麻将可以左斜着放入网格中&#xff08;如 / &#xff09;&#xff0c;也可以右斜着&am…

P6773 [NOI2020] 命运(dp、线段树合并)

前言 一道看起来很毒瘤但其实还算小清新的题&#xff1f; 理解后感觉其实并没有那么难。 暴力分非常足&#xff0c;好评。 奇妙的线段树合并技巧增加了。 解析 解法1 你是怎么手玩的样例一&#xff1f; 大部分&#xff08;比如我&#xff09;都是容斥吧。 把手玩的方法搬到…

ConsurrentDictionary并发字典知多少?

在上一篇文章你真的了解字典吗?一文中我介绍了Hash Function和字典的工作的基本原理.有网友在文章底部评论,说我的Remove和Add方法没有考虑线程安全问题.https://docs.microsoft.com/en-us/dotnet/api/system.collections.generic.dictionary-2?redirectedfromMSDN&viewn…

[luogu 4292][bzoj 1758][WC2010] 重建计划(点分治 + dp + 单调队列优化 + 启发式合并)

[WC2010]重建计划problemsolutioncodeproblem 洛谷指路 solution 一看那个道路平均价值的式子&#xff1a;AvgValue∑e∈Sv(e)∣S∣\text{AvgValue}\frac{\sum_{e\in S}v(e)}{|S|}AvgValue∣S∣∑e∈S​v(e)​ 就是 0/1分数规划 的样子。 所以考虑二分最终的答案 midmidmid…

cf1553C. Penalty

cf1553C. Penalty 题意&#xff1a; 有十轮点球&#xff0c;两个队伍轮流进行&#xff0c;1表示进&#xff0c;0表示不进&#xff0c;&#xff1f;表示未知&#xff0c;如果比赛没有了悬念将直接结束。现在让你预测一个情况&#xff0c;使得进行的轮数最少。裁判在决定停止点…

ASP.NET Core 基于JWT的认证(二)

上一节我们对 Jwt 的一些基础知识进行了一个简单的介绍&#xff0c;这一节我们将详细的讲解,本次我们将详细的介绍一下 Jwt在 .Net Core 上的实际运用。.Net Core 2.2Visual Studio 2017ASP.NET Core WebAPI2在上一篇文章中&#xff0c;我们详细的介绍了JWT的知识&#xff0c;这…

P6774 [NOI2020] 时代的眼泪(分块)

前言 看到题目名&#xff1a;别骂了别骂了。 一道很中规中矩的YNOI吧。 卡在整块对整块的贡献上了。 这也确实算是本题最不好做的部分了。 前置知识&#xff1a;Yuno loves sqrt technology I 解析 区间逆序对加强版&#xff1f;很难不想到两道 YLST。 然而多了两维限制&a…

[NOIP2021] 数列(计数dp)

solution f[i][j][k][num][p]:2pf[i][j][k][num][p]:2^pf[i][j][k][num][p]:2p 选择了 iii 个&#xff0c;前 p−1p-1p−1 位 (202p−1)(2^0~2^{p-1})(20 2p−1) 已经选了jjj个&#xff0c;低位向高位进位上来 kkk&#xff0c;前 ppp 位已经确定有 numnumnum 个位置为 111&…

Xor sum HDU - 6955

Xor sum HDU - 6955 题意&#xff1a; 给定一个长度为n的整数序列&#xff0c;求其XOR和不小于k的最短连续子序列。 如果有多个相同长度的连续子序列&#xff0c;则打印具有最小左端点的连续子序列。 如果没有连续的子序列开关XOR总和不小于k&#xff0c;只需打印“-1”。 …

模板:子序列自动机(字符串)

所谓子序列自动机&#xff0c;就是根据子序列建立的自动机。 &#xff08;逃&#xff09; 前言 小清新算法。 解析 和其他自动机类似的&#xff0c;我们希望子序列自动机能且只能接受原串的所有子序列。 考虑一个问题&#xff1a;给你一个串 T&#xff0c;如何判断它是否是…