sssmalong556 2022-03-20 09:58 采纳率: 0%
浏览 9

我想问一下为啥我运行结果不对啊(DNA的汉明距离问题)

已经从txt文件里面读取出来五个dna序列了

for(int i=0;i<8;i++) {
int countA=0;
int countT=0;
int countG=0;
int countC=0; //每个位置循环过后要清零

              for(int j=0;j<m;j++) {
                  //对每个序列每个位置上的字母进行统计
                  if(s[j].charAt(i)=='A') {
                      countA++;
                      }
                  if(s[j].charAt(i)=='T') {
                      countT++;
                      }
                  if(s[j].charAt(i)=='G') {
                      countG++;
                      }
                  if(s[j].charAt(i)=='C') {
                      countC++;
                      }
              }
    optimal+=max(countA,countG,countT,countC);
      //输出字符串
      
      }
        System.out.println("the optimal sequence is:");
        System.out.println(optimal);

}
private static char max(int countA, int countC, int countG, int countT) {
//比较每一位重复最多的字母 并返回字母
for(int k=0;k<4;k++) {
int a[]=new int[4];
a[0]=countA;
a[1]=countC;
a[2]=countG;
a[3]=countT;
int max=a[0];
for(int i=1;i<4;i++) {
if(a[i]>max) {
max=a[i];
}
}
if(max==countA) {
return 'A';
}
else if(max==countC) {
return 'C';
}
else if(max==countG) {
return 'G';
}
else if(max==countT) {
return 'T';
}

      }
return ' '; 

    
  }
       

}

  • 写回答

1条回答 默认 最新

  • CSDN专家-link 2022-03-20 10:04
    关注

    为啥要for(int k=0;k<4;k++) 这层循环呢???

    private static char max(int countA, int countC, int countG, int countT) 
    {
        int m1 = countA > countC ? countA:countC;
        int m2 = countG > countT ? countG:countT;
        int m = m1 > m2 ? m1:m2;
        switch(m)
        {
            case countA:
                return 'A';
            case countC:
                return 'C';
            case countG:
                return G;
            case countT:
                return T;
        }
        return ' ';
    }
    
    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 3月20日

悬赏问题

  • ¥15 请问Ubuntu要怎么安装chrome呀?
  • ¥15 视频编码 十六进制问题
  • ¥15 Xsheii7我安装这个文件的时候跳出来另一个文件已锁定文件的无一部分进程无法访问。这个该怎么解决
  • ¥15 unity terrain打包后地形错位,跟建筑不在同一个位置,怎么办
  • ¥15 FileNotFoundError 解决方案
  • ¥15 uniapp实现如下图的图表功能
  • ¥15 u-subsection如何修改相邻两个节点样式
  • ¥30 vs2010开发 WFP(windows filtering platform)
  • ¥15 服务端控制goose报文控制块的发布问题
  • ¥15 学习指导与未来导向啊