您的位置:首页 > 其它

POJ 1007 DNA Sorting(水题) 逆…

2013-06-13 15:38 369 查看
题意:有N段长为M的子串,要求将子串按照子串逆序数从小到大的顺序输出。

 

分析:难度不大,主要就是一点小问题的处理,Since two strings can be equally sorted, then output them according to the orginal order.这句话尤为重要,开始WA了一次,也是由于没有注意到这句话,当两个子串逆序相同的时候,按照原始顺序输出

 

开始在输出的时候少了一小行防止重复出现的代码,于是就WA了。

 

另外,我的思路,是用数组先存所有逆序数,然后再排序,所以,原始的数组要保留一下,用另外一个数组copy就行。

  

贴下代码:(204k,0ms)

 

C++语言:


#include<iostream>
#include<algorithm>
using
namespace
std;
int
main()
{

   int n,m;

   cin>>n>>m;

   int i ,
j , k;

   int times;

   char t[105][55];

   int num[105]={0};

   int temp[105]={0};

   for(times=0;times<m;times++)

   {

     
 for(i=0;i<n;i++)

     
   
 cin>>t[times][i];

     
 for(j=0;j<n;j++)

     
   
 for(k=j+1;k<n;k++)

     
     
   if(t[times][j]>t[times][k])num[times]++;

     
 temp[times]=num[times];

   }

   sort(num,num+m);

   for(i=0;i<m;i++)

   {

     
 for(times=0;times<m;times++)

     
 {

     
   
 if(temp[times]==num[i])
     
     

     
     
   for(k=0;;k++)

     
     
   {

     
     
     
 cout<<t[times][k];

     
     
     
 if(k==n-1)

     
     
     
 {

     
     
     
   
 cout<<endl;

     
     
     
   
 temp[times]=-1;

     
     
     
   
 break;

     
     
     
 }
   

     
     
   }

     
 }

   }
}

 

 

 

对最后一段代码的解释:temp[times]也是从小到大的方式一点点查的,所以如果有两个相同的话肯定是按照顺序先输出第一个,然后输完后要把这一个temp[times]重新设置个负数,这样的话就不会再重复

 

收获:重新温习了一下逆序数的求法,防重复的方法一开始也没想到,经过和别人交流才想到,对于这些基础的题目的掌握还不是特别的熟练,思路还不够开阔,刷的题目太少太少,要不断进步,不断学习。这几天因为兼职和做家教的缘故,自己对自己有很明显的放纵,总是想偷懒,必须迅速改变这种状态,不可让这种恶习持续!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: