北大ACM(POJ1007-DNA Sorting)

Question:http://poj.org/problem?id=1007
问题点:逆序数及快排。
 1 Memory: 248K        Time: 0MS
 2 Language: C++        Result: Accepted
 3 
 4 #include <iostream>
 5 #include <string>
 6 #include <stdlib.h>
 7 
 8 using namespace std;
 9 struct nm
10 {
11     char str[50];
12     int cnt;
13 };
14 int mycmp(const void *a,const void *b)
15 {
16     nm *nma=(nm*)a;
17     nm *nmb=(nm*)b;
18     return nma->cnt-nmb->cnt;
19 }
20 int main()
21 {
22     int n,m;
23     nm NM[100];
24     cin>>n>>m;
25     memset(NM,0,sizeof(NM));
26     for(int i=0;i<m;i++)
27     {
28         cin>>NM[i].str;
29         int len=strlen(NM[i].str);
30         for(int j=0;j<len;j++)
31         {
32             for(int k=j+1;k<len;k++)
33             {
34                 if(NM[i].str[j]>NM[i].str[k]) NM[i].cnt++;
35             }
36         }
37     }
38     qsort(NM,m,sizeof(nm),mycmp);
39     for(int i=0;i<m;i++)
40     {
41         cout<<NM[i].str<<endl;
42     }
43     return 0;
44 }

 

 

转载于:https://www.cnblogs.com/TYcnblogs/p/poj1007.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值