Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- import java.io.*;
- import java.util.*;
- public class Main {
- void solve() {
- int t = in.nextInt();
- HashMap<String, HashMap<String, Integer>> adj = new HashMap<>();
- long pairs = 0;
- for (int tt = 0; tt < t; tt++) {
- String s = in.next();
- String prev = null;
- for (int i = 0; i < s.length() - 2; i++) {
- String w = s.substring(i, i + 3);
- if (!adj.containsKey(w)) {
- adj.put(w, new HashMap<>());
- }
- if (prev != null) {
- int old = 0;
- if (adj.get(prev).containsKey(w)) {
- old = adj.get(prev).get(w);
- } else {
- pairs++;
- }
- int incremented = old + 1;
- adj.get(prev).put(w, incremented);
- }
- prev = w;
- }
- }
- out.println(adj.size());
- out.println(pairs);
- for (String a : adj.keySet()) {
- for (String b : adj.get(a).keySet()) {
- out.println(a + " " + b + " " + adj.get(a).get(b));
- }
- }
- }
- Scanner in;
- PrintWriter out;
- void run() {
- try {
- in = new Scanner(new File("A.in"));
- out = new PrintWriter(new File("A.out"));
- solve();
- out.close();
- } catch (FileNotFoundException e) {
- e.printStackTrace();
- }
- }
- void runIO() {
- in = new Scanner(System.in);
- out = new PrintWriter(System.out);
- solve();
- out.close();
- }
- class Scanner {
- BufferedReader br;
- StringTokenizer st;
- public Scanner(File f) {
- try {
- br = new BufferedReader(new FileReader(f));
- } catch (FileNotFoundException e) {
- e.printStackTrace();
- }
- }
- public Scanner(InputStream f) {
- br = new BufferedReader(new InputStreamReader(f));
- }
- String next() {
- while (st == null || !st.hasMoreTokens()) {
- String s = null;
- try {
- s = br.readLine();
- } catch (IOException e) {
- e.printStackTrace();
- }
- if (s == null)
- return null;
- st = new StringTokenizer(s);
- }
- return st.nextToken();
- }
- private boolean isSpaceChar(int c) {
- return !(c >= 33 && c <= 126);
- }
- private int skip() {
- int b;
- while ((b = read()) != -1 && isSpaceChar(b)) ;
- return b;
- }
- private int read() {
- int res = -1;
- try {
- res = br.read();
- } catch (IOException e) {
- e.printStackTrace();
- }
- return res;
- }
- char[] nextCharArray(int size) {
- char[] buf = new char[size];
- int b = skip(), p = 0;
- while (p < size && !(isSpaceChar(b))) {
- buf[p++] = (char) b;
- b = read();
- }
- return size == p ? buf : Arrays.copyOf(buf, p);
- }
- char[][] nextCharMap(int n, int m) {
- char[][] map = new char[n][];
- for (int i = 0; i < n; i++) {
- map[i] = nextCharArray(m);
- }
- return map;
- }
- boolean hasMoreTokens() {
- while (st == null || !st.hasMoreTokens()) {
- String s = null;
- try {
- s = br.readLine();
- } catch (IOException e) {
- e.printStackTrace();
- }
- if (s == null)
- return false;
- st = new StringTokenizer(s);
- }
- return true;
- }
- int nextInt() {
- return Integer.parseInt(next());
- }
- long nextLong() {
- return Long.parseLong(next());
- }
- double nextDouble() {
- return Double.parseDouble(next());
- }
- }
- public static void main(String[] args) {
- new Main().runIO();
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment