public static void main(String[] args) {
String url = "https://leetcode.com/problems/encode-and-decode-tinyurl/discuss/";
String encode = encode(url);
String decode = decode(encode);
System.out.println(url);
System.out.println(encode);
System.out.println(decode);
}
static Map<String,String> map = new HashMap<>();
static String base = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
// Encodes a URL to a shortened URL.
public static String encode(String longUrl) {
Integer i = longUrl.hashCode();
map.put(base10ToBase62(i.longValue()),longUrl);
return "http://tinyurl.com/"+base10ToBase62(i.longValue());
}
// Decodes a shortened URL to its original URL.
public static String decode(String shortUrl) {
String s = map.get(shortUrl.replaceAll("http://tinyurl.com/",""));
return s;
}
public static String base10ToBase62(Long n) {
StringBuilder sb = new StringBuilder();
while (n != 0) {
Long l = n % 62;
sb.insert(0,base.charAt(l.intValue()));
n /= 62;
}
return sb.toString();
}
public static Long base62ToBase10(String str) {
Long n = 0l;
for (int i = 0; i < str.length(); i++) {
n=n*62+base.indexOf(str.charAt(i));
}
return n;
}
public int convert(char c) {
if (c >= '0' && c <= '9')
return c - '0';
if (c >= 'a' && c <= 'z') {
return c - 'a' + 10;
}
if (c >= 'A' && c <= 'Z') {
return c - 'A' + 36;
}
return -1;
}
tinyUrl
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...