ACM1007
题目:DNA序列排序
DNA序列由一序列的大写英文字母表示,如ABCDEF。紊乱程度表示组成DNA序列的字母按照由小到大的顺序进行排列程度,如ABC的紊乱程度比ACB小,因为它字母都是由小到大排序的。紊乱程度计算如下,以DNA序列DCEFB为例:DCEFB的紊乱程度为5,其中字母D右边的序列有2个小于它的字母C和B,字母C有1个小于它的字母B,同理,字母E和F分别有1个排序小于它的字母,紊乱程度=2+1+1+1=5。紊乱程度越大,排序越乱。
程序输入:
第1行输入m和n,其中m表示每一个DNA序列的长度,n表示一共有多少个DNA序列;第2到n行输入DNA序列,每一个DNA序列的长度都为m。m的取值范围为1-100,即DNA序列的长度不超过100,n的范围为1-50,表示最多有50个DNA序列。
结果输出:
按照DNA的紊乱程度由小到大进行排序,如果两个DNA序列的紊乱程度相同,则按照输入的顺序进行排序。
程序设计—(时间16ms,占用空间200k):
#include <iostream>
#include <string> using namespace std; void qsort(int startIndex,int EndIndex,int *vector,string *values){
int start=startIndex;
int end=EndIndex;
int currentValue = *(vector+start);
string currentStr = *(values+start);
while(start<end){
while(start<end&&*(vector+end)>=currentValue){
end--;
}
*(vector+start)=*(vector+end);
*(values+start)=*(values+end);
while(start<end&&*(vector+start)<=currentValue){
start++;
}
*(vector+end)=*(vector+start);
*(values+end)=*(values+start);
}
*(vector+end)=currentValue;
*(values+end)=currentStr;
if(end->startIndex){
qsort(startIndex,end-,vector,values);
}
if(end+<EndIndex)
{
qsort(end+,EndIndex,vector,values);
}
} int main()
{
char line[];
string str;
int *numOfLines=new int[];
int index=;
int *values=new int[];
string *allStr=new string();
int totalLine=;
int leterNum=;
cin>>leterNum>>totalLine;
numOfLines = new int[totalLine];
allStr = new string[totalLine];
values = new int[leterNum];
while (index<totalLine)
{
cin>>line;
str = line;
*(allStr+index)=line;
int count=;
for(int i=;i<leterNum;i++){
int l = line[i]-'A';
*(values+i)=l;
for(int j=i-;j>=;j--){
if(*(values+j)>*(values+i)){
count++;
}
}
}
(*(numOfLines+index))=count;
index++;
}
qsort(,totalLine-,numOfLines,allStr);
for(int i=;i<totalLine;i++){
cout<<*(allStr+i)<<endl;
}
return ;
}
1007是简单题,主要考察一些小细节,有几个需要注意的地方:
(1)数组和指针的问题(由于本人刚刚接触C++,在指针上确实花了一些时间)
数组的指针可以表示第一个元素的位置,然后通过++可以得到其他元素的指针。
如:int *pointer = new int[10];
新建一个10个元素的数组,pointer指向该数组第一个元素的地址,pointer++表示数组第二个元素的地址,pointer+i表示数组第pointer+i个元素。
(2)第二个是输入的问题
弄清楚几个输入的关键方法:
>>、getLine、gets、get_s、fget
ACM1007的更多相关文章
- 杭电ACM1007
Quoit Design Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- C# ACM poj1007
求逆序数,快排 public static void acm1007(int a, string[] c) { Dictionary<int, string> dic = new Dict ...
随机推荐
- 使用exe4j工具制作简单的java应用程序
首先需要下载exe4j工具并进行安装,下面是利用exe4j工具制作应用程序的步骤. 1.首先将工程导出为可运行的jar包,选择extract required libralies into gener ...
- BZOJ 3782: 上学路线 [Lucas定理 DP]
3782: 上学路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 192 Solved: 75[Submit][Status][Discuss] ...
- BZOJ 1502: [NOI2005]月下柠檬树 [辛普森积分 解析几何 圆]
1502: [NOI2005]月下柠檬树 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 1070 Solved: 596[Submit][Status] ...
- HDU3488 Tour [有向环覆盖 费用流]
Tour Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total Submis ...
- springMvc+swagger整合例子
Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法,参数和模型紧密集成到服 ...
- hbuilder ios 打包失败,无法导入p12证书的解决方案
问题描述: 在profile文件和私钥证书通过hbuilder ios 打包成功过的前提下,突然遇到打包失败的问题,问题详情是无法导入p12证书. 探索过程: 本着遇到问题先自省的态度,重复打包了几次 ...
- 使用单元素的枚举类型实现Singleton
从java1.5版本开始,实现singleton出现了第三种方式: public enum SingleTon { INSTANCE; public void speak() { System.out ...
- 自动统计安卓log中Anr,Crash,Singnal出现数量的Python脚本
作为测试,在测试工作中一定会经常抓log,有时log收集时间很长,导致log很大,可能达到几G,想找到能打开如此大的log文件的工具都会变得困难:即使log不大时,我们可以直接把log发给开发同学去分 ...
- Linux下 开启防火墙端口
命令行输入: vi /etc/sysconfig/iptables 将 -A INPUT -m state --state NEW -m tcp -p tcp --dport 端口号 -j ACCEP ...
- java定时器schedule和scheduleAtFixedRate区别
package cn.lonecloud.test; import java.util.Date; import java.util.Timer; import java.util.TimerTask ...