现在需要实现一个长链接转短链接的算法。该算法会将原始长链接转换成一个以"https://short.url/"开头的、后接6位映射字符的短链接。算法描述如下: ① 计算key值。key初始为1,每次...

以下是用 Java 语言实现的代码:

``` import java.util.HashMap;

public class ShortURL { private static final String SHORT_URL_PREFIX = "https://short.url/"; private static final int DICTIONARY_LENGTH = 62; private static final String DICTIONARY = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"; private static final long PRIME = 56800235584L; private static HashMap<String, String> longToShortMap = new HashMap<>(); private static HashMap<String, String> shortToLongMap = new HashMap<>();

public static String[] longToShort(String[] urls) {
    String[] shortUrls = new String[urls.length];
    for (int i = 0; i < urls.length; i++) {
        String longUrl = urls[i];
        if (longToShortMap.containsKey(longUrl)) {
            // 如果已经被转换过,直接返回已转换的短地址
            shortUrls[i] = longToShortMap.get(longUrl);
        } else {
            long key = 1;
            // 计算 key
            for (int j = 0; j < longUrl.length(); j++) {
                key = (key * 64 + (long)longUrl.charAt(j)) % PRIME;
            }
            // 遇到 key 冲突的情况
            while (shortToLongMap.containsKey(key)) {
                key = (key + 1) % PRIME;
            }
            // 建立 key 与 6 位字符的映射
            StringBuilder shortUrlBuilder = new StringBuilder();
            while (key > 0) {
                shortUrlBuilder.insert(0, DICTIONARY.charAt((int)(key % DICTIONARY_LENGTH)));
                key /= DICTIONARY_LENGTH;
            }
            // 映射字符不足 6 位,前面加 0
            while (shortUrlBuilder.length() < 6) {
                shortUrlBuilder.insert(0, '0');
            }
            String shortUrl = SHORT_URL_PREFIX + shortUrlBuilder.toString();
            // 更新映射表
            longToShortMap.put(longUrl, shortUrl);
            shortToLongMap.put(shortUrl, longUrl);
            shortUrls[i] = shortUrl;
        }
    }
    return shortUrls;
}

public static String[] shortToLong(String[] urls) {
    String[] longUrls = new String[urls.length];
    for (int i = 0; i < urls.length; i++) {
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值