此程序耗费我尽3个小时之久,原因是做题前的规划没做好,一直没有想到整体排序的好办法,最后还是用了注意匹配的方法才解决了问题,我不知道为什么用冒泡不行,第一个字符串总是乱码。我觉得整体思路还是比较清晰的,只是方法可能有点傻,效率还行。
C 编译器 : 172K 0MS
#include <stdio.h>
#include <string.h>
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
typedef struct DNA
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
{
char str[50]; // 存储字符串
int count[2]; // [0] [1]都存放串的逆序数
}DNA; // [1]中作为参考,用来和排序后的[0]匹配
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
int main()
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
{
int i=0,j,k=0,n,m,temp;
DNA or[100];
scanf("%d%d",&n,&m);
while (k<m) //获得数据并求各自逆序数
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
{
scanf("%s",&or[k].str);
or[k].count[0]=0; // 此步不能忘
for (i=0; i<n; i++)
for (j=i+1; j<n; j++)
if (or[k].str[i] > or[k].str[j])
or[k].count[0]++;
k++;
}
for (i=0; i<m; i++)
or[i].count[1]=or[i].count[0]; // 原逆序数存放顺序
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
for (i=1; i<m; i++) // 对于各组串的逆序数进行排序,count[0]内容已打乱
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
{
k=i-1;
for (j=i; j<m; j++)
if (or[j].count[0] < or[k].count[0])
k=j;
temp=or[i-1].count[0];
or[i-1].count[0]=or[k].count[0];
or[k].count[0]=temp;
} // 这是典型的选择排序,只是对[0]单元的处理,稳定与否没关系
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
for (i=0; i<m; i++)
for (j=0; j<m; j++)
if (or[i].count[0] == or[j].count[1]) // [0] 和 [1] 中逐一相比较
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
{
or[j].count[1]=-1; // 此步是相等时顺序不变的保证,相当于做了访问标记!
printf("%s\n",or[j].str);
}
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt="POJ 1007 DNA sorting - Icho - Brian Warehouse POJ 1007 DNA sorting - Icho - Brian Warehouse"
return 0;
}