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 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 javax.imageio.*;
import java.math.*;
import it.unimi.dsi.fastutil.objects.Object2IntRBTreeMap;
class main {
// fastutil Object2IntRBTreeMap
public static void main(final String[] args) throws Exception {
Object2IntRBTreeMap < String > map = new Object2IntRBTreeMap(caseInsensitiveComparator());
map.put("a", 5);
map.put("A", 10);
map.put("b", 3);
printStruct(map);
assertEquals(10, map.get("a"));
assertEquals(10, map.get("A"));
print("OK");
}
static A printStruct(String prefix, A a) {
printStructure(prefix, a);
return a;
}
static A printStruct(A a) {
printStructure(a);
return a;
}
static Comparator caseInsensitiveComparator() {
return String.CASE_INSENSITIVE_ORDER;
}
static volatile StringBuffer local_log = new StringBuffer(); // not redirected
static volatile StringBuffer print_log = local_log; // might be redirected, e.g. to main bot
// in bytes - will cut to half that
static volatile int print_log_max = 1024*1024;
static volatile int local_log_max = 100*1024;
//static int print_maxLineLength = 0; // 0 = unset
static boolean print_silent; // total mute if set
static Object print_byThread_lock = new Object();
static volatile ThreadLocal