import java.util.*; import java.util.zip.*; import java.util.List; import java.util.regex.*; import java.util.concurrent.*; import java.util.concurrent.atomic.*; import java.util.concurrent.locks.*; import java.util.function.*; import javax.swing.*; import javax.swing.event.*; import javax.swing.text.*; import javax.swing.table.*; import java.io.*; import java.net.*; import java.lang.reflect.*; import java.lang.ref.*; import java.lang.management.*; import java.security.*; import java.security.spec.*; import java.awt.*; import java.awt.event.*; import java.awt.image.*; import java.awt.geom.*; import javax.imageio.*; import java.math.*; class main { static List hashRefTok(String s) { ArrayList tok = new ArrayList(); int l = s == null ? 0 : s.length(); int i = 0; while (i < l) { int j = i; char c; // scan for whitespace while (j < l) { if (j < l-1 && s.charAt(j) == '#') { c = s.charAt(j+1); if (Character.isJavaIdentifierStart(c) || Character.isDigit(c) || c == '(') break; } j++; } tok.add(quickSubstring(s, i, j)); i = j; if (i >= l) break; // scan for non-whitespace i++; // skip # c = s.charAt(i); if (Character.isJavaIdentifierStart(c)) { do ++j; while (j < l && Character.isJavaIdentifierPart(s.charAt(j))); } else if (Character.isDigit(c)) { do ++j; while (j < l && Character.isDigit(s.charAt(j))); } else if (c == '(') { do ++j; while (j < l && s.charAt(j) != ')'); j = Math.min(j+1, l); } else ++j; // not needed but added for safety tok.add(quickSubstring(s, i, j)); i = j; } if ((tok.size() & 1) == 0) tok.add(""); return tok; } static String quickSubstring(String s, int i, int j) { if (i >= j) return ""; return s.substring(i, j); } }