SDNU-1093.DNA排序
Description
逆序数可以用来是描述一个序列混乱成度的量。例如,“DAABEC”的逆序数为5,其中D大于它右边的4个数,E大于它右边的1个数,4+1=5;又例如“ZWQM”的逆序数为3+2+1+0=6。
现在有许多长度一样的字符串,每个字符串里面只会出现四种字母(A,T,G,C)。你现在被要求编写程序将这些字符串按照他们的逆序数进行排序
Input
第一行包括两个正整数,第一个正整数N给出了字符串的长度,第二个正整数M给出了字符串的数量。(1<=N,M<=100)
接下来M行每行一个长度为N的字符串,只包含A,T,G,C四种字母。
Output
将输入的字符串按照其逆序数进行排序,如果两个字符串的逆序数相等,则按照输入中两者的先后顺序进行排列。
Sample Input
10 6
AACATGAAGG
TTTTGGCCAA
TTTGGCCAAA
GATCAGATTT
CCCGGGGGGA
ATCGATGCAT
Sample Output
CCCGGGGGGA
AACATGAAGG
GATCAGATTT
ATCGATGCAT
TTTTGGCCAA
TTTGGCCAAA
Hint
选择排序是不稳定的
这题关键是hint:选择排序是不稳定的,(不稳定排序:大小相等的元素在被排序后前后位置关系可能改变)也就是说,不能简单的用sort来排序(不知道为什么stable_sort也不对),所以就在结构体排序上做文章使其满足output中的:如果两个字符串的逆序数相等,则按照输入中两者的先后顺序进行排列,所以我在结构体中int了一个出现顺序的量。ac代码如下(没有修改一些我尝试的细节):
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <string>
#include <cstdio>
using namespace std;
#define N 105
struct node
{
char s[N];
long long f;
int i;
};
bool cmp (node x,node y)
{
if (x.f!=y.f)
return x.f<y.f;
else
return x.i<y.i;
}
int main()
{
long long n,m;
cin>>n>>m;
node a[105];
for (int i=0;i<m;i++)
{
cin>>a[i].s;
a[i].i=i;
long long sum=0;
for (int j=0;j<n-1;j++)
for (int k=j+1;k<n;k++)
{
if (a[i].s[j]>a[i].s[k])
sum++;
}
a[i].f=sum;
}
sort(a,a+m,cmp);
for (int i=0;i<m;i++)
cout<<a[i].s<<endl;
return 0;
}
若有问题请联系,我只是一个菜鸡。我会在你们的批评中变得优秀!