Sha256: 1fc2ee303bb0974c985b9c6875430e1cf3aa35f975f03a08f96b9af79d25df94

Contents?: true

Size: 1.03 KB

Versions: 218

Compression:

Stored size: 1.03 KB

Contents

import java.util.HashMap;
import java.util.Map;

public final class DNA {
  private final String sequence;

  public DNA(String sequence) {
    this.sequence = sequence;
  }

  public int count(char base) {
    if (isCountable(base))
      throw new IllegalArgumentException(base + " is not a nucleotide");

    try {
      return nucleotideCounts().get(base);
    } catch (NullPointerException e) {
      return 0;
    }
  }

  private static boolean isCountable(char base) {
    final String COUNTABLE_NUCLEOTIDES = "ACGT";
    return COUNTABLE_NUCLEOTIDES.indexOf(base) == -1;
  }

  public Map<Character, Integer> nucleotideCounts() {
    Map<Character, Integer> counts = emptyCounts();
    for (char c : sequence.toCharArray()) {
      counts.put(c, counts.get(c) + 1);
    }
    return counts;
  }

  private static Map<Character, Integer> emptyCounts() {
    Map<Character, Integer> counts = new HashMap<Character, Integer>();
    counts.put('A', 0);
    counts.put('C', 0);
    counts.put('T', 0);
    counts.put('G', 0);
    return counts;
  }
}

Version data entries

218 entries across 218 versions & 1 rubygems

Version Path
trackler-2.0.8.38 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.37 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.36 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.35 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.34 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.33 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.32 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.31 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.30 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.29 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.28 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.27 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.26 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.24 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.23 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.22 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.21 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.20 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.19 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java
trackler-2.0.8.18 tracks/java/exercises/nucleotide-count/src/example/java/DNA.java