`
翼若云
  • 浏览: 6549 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

POJ1007 DNA Sorting

    博客分类:
  • poj
 
阅读更多

这个主要是计算字符串的逆序数并且排序。

 

 

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner cin=new Scanner(System.in);
        int strLen = cin.nextInt();
        int strCount = cin.nextInt();
        cin.nextLine();
        List<DNA> dnaList = new ArrayList<DNA>();

        for(int idx = 0;idx<strCount;idx++){
            String dnaStr = cin.nextLine();
            dnaList.add(new DNA(dnaStr,calcInversionNum(dnaStr)));
        }

        Collections.sort(dnaList,new Comparator<DNA>() {
            public int compare(DNA o1, DNA o2) {
                return o1.getInversionNum()-o2.getInversionNum();
            }
        });


        for (DNA dna : dnaList) {
            System.out.println(dna.getDnaStr());
        }
    }
    
    private static int calcInversionNum(String dnaStr){
        char[] charArray = dnaStr.toCharArray();
        int inversionNum = 0;
        for (int i = 0; i < charArray.length; i++) {
            char c = charArray[i];
            for (int j = i+1;j < charArray.length;j++){
                if(c>charArray[j]){
                    inversionNum++;
                }
            }
        }
        return inversionNum;
    }
    
    
    static class  DNA {
        private String dnaStr;
        private int inversionNum;

        DNA(String dnaStr, int inversionNum) {
            this.dnaStr = dnaStr;
            this.inversionNum = inversionNum;
        }

        public String getDnaStr() {
            return dnaStr;
        }

        public void setDnaStr(String dnaStr) {
            this.dnaStr = dnaStr;
        }

        public int getInversionNum() {
            return inversionNum;
        }

        public void setInversionNum(int inversionNum) {
            this.inversionNum = inversionNum;
        }
    }
}

 

 

分享到:
评论

相关推荐

    poj 1007 DNA Sorting

    DNA Sorting Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 34868 Accepted: 13480 Description One measure of ``unsortedness'' in a sequence is the number of pairs of entries that are ...

    POJ1007-DNA Sorting

    【标题】"POJ1007-DNA Sorting"是一个编程竞赛题目,源自北京大学的在线判题系统POJ(Problem Online Judge)。这个题目要求参赛者编写程序,对DNA序列进行排序,具体而言,就是对一系列由ATCG四种碱基组成的DNA字符...

    poj dna sorting

    poj dna sorting 问题,研究的ac coderrrrrrr

    poj1007AC代码

    poj1007 AC代码 0MS过题写法 不过是个水题 哈哈哈哈

    poj1007代码

    poj1007题代码,DNA问题,C++语言,map

    POJ1094-Sorting It All Out

    【标题】"POJ1094-Sorting It All Out" 是一道来自北京大学在线判题系统POJ(Problem Set)的编程题目。这道题目主要考察的是排序算法的应用与优化,旨在提高参赛者的算法设计和实现能力。 【描述】"北大POJ1094-...

    poj 1007代码

    ACM是很好的,多在OJ上练习,你会有惊喜的。很能增加您的技能。

    poj DNA排序

    简单的字符串操作和求逆序对数,是程设poj习题

    East Central North America 1998测试数据

    "East Central North America 1998测试数据" 提供的是一组与1998年东中北美地区编程竞赛相关的测试资源,特别提及了POJ(Problem Set of Peking University Online Judge)中的1007DNA Sorting问题。这个标题暗示了...

    POJ.rar_poj java_poj1048

    【标题】"POJ.rar_poj java_poj1048" 涉及的知识点主要围绕编程竞赛中的“约瑟夫环”问题,这里是一个加强版,使用Java语言进行解决。 【描述】"POJ1048,加强版的约瑟夫问题 难度中等" 提示我们,这个问题是编程...

    jihe.rar_2289_POJ 3714_poj3714_poj3714 Ra_visual c

    描述中提到的"三道几何题:hdu 1007、hdu 2289、poj 3714"暗示了这是一个关于几何算法的题目集,涉及到三个不同的在线判题系统:HDU(杭州电子科技大学在线评测系统)的1007题和2289题,以及POJ的3714题。...

    POJ算法题目分类

    * 图的深度优先遍历和广度优先遍历:图的深度优先遍历和广度优先遍历是指遍历图的两种方式,如 poj1860、poj3259、poj1062、poj2253、poj1125、poj2240。 * 最短路径算法:最短路径算法是指计算图中两点之间的最短...

    POJ1159-Palindrome

    【标题】"POJ1159-Palindrome" 是北京大学在线编程平台POJ上的一道编程题目。这道题目主要考察的是字符串处理和回文判断的知识点。 【描述】"北大POJ1159-Palindrome 解题报告+AC代码" 暗示了解决这道问题的方法和...

    强大POJ分类,新手进阶用

    数学类题目是POJ中常见的类型,例如1007DNA Sorting涉及到排序算法,1338Ugly Numbers需要理解并生成丑数序列,1664放苹果则可能涉及到组合数学和贪心策略。这些题目挑战着用户的逻辑思维和数学功底。 此外,还有...

    ACM-POJ 算法训练指南

    1. **状态转移方程**:设计复杂的动态规划状态转移方程(poj1191, poj1054, poj3280, poj2029, poj2948, poj1925, poj3034)。 2. **记忆化搜索**:结合动态规划和递归搜索(POJ3254, poj2411, poj1185)。 3. **...

    poj训练计划.doc

    根据给定的文件信息,我们可以总结出一份详细的IT知识训练计划,主要针对编程竞赛和算法学习,特别是聚焦于POJ(Problem Online Judge)平台上的题目训练。这份计划分为两个阶段,初级阶段和中级阶段,共计涉及了165...

    POJ3253-POJ3253-Fence Repair【STL优先队列】

    标题“POJ3253-POJ3253-Fence Repair【STL优先队列】”指的是一个在线编程竞赛题目,源自北京大学的在线判题系统POJ(Problem Online Judge)。该题目要求参赛者使用C++编程语言解决特定的问题,并且在解决方案中...

    POJ2002-Squares

    【标题】"POJ2002-Squares"是一个经典的计算机编程题目,源自北京大学的在线判题系统(POJ,即PKU Online Judge)。这个题目主要涉及到算法设计和实现,尤其是数学和动态规划方面的知识。 【描述】"解题报告+AC代码...

    poj题目分类

    * 较为复杂的动态规划:例如 poj1191、poj1054、poj3280、poj2029、poj2948、poj1925、poj3034。 数学 1. 组合数学: * 加法原理和乘法原理。 * 排列组合。 * 递推关系:例如 poj3252、poj1850、poj1019、poj...

    POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类

    - **例题**:poj1860, poj3259, poj1062, poj2253, poj1125, poj2240 - **解释**:最短路径算法包括Dijkstra算法、Bellman-Ford算法、Floyd算法以及堆优化的Dijkstra算法等。 ##### (3) 最小生成树算法 - **例题**...

Global site tag (gtag.js) - Google Analytics