Note: This is a companion problem to the System Design problem: Design TinyURL.
TinyURL is a URL shortening service where you enter a URL such as https://leetcode.com/problems/design-tinyurl
and it returns a short URL such as http://tinyurl.com/4e9iAk
. Design a class to encode a URL and decode a tiny URL.
There is no restriction on how your encode/decode algorithm should work. You just need to ensure that a URL can be encoded to a tiny URL and the tiny URL can be decoded to the original URL.
Implement the Solution
class:
Solution()
Initializes the object of the system.String encode(String longUrl)
Returns a tiny URL for the givenlongUrl
.String decode(String shortUrl)
Returns the original long URL for the givenshortUrl
. It is guaranteed that the givenshortUrl
was encoded by the same object.
Example 1:
Input: url = "https://leetcode.com/problems/design-tinyurl" Output: "https://leetcode.com/problems/design-tinyurl" Explanation: Solution obj = new Solution(); string tiny = obj.encode(url); // returns the encoded tiny url. string ans = obj.decode(tiny); // returns the original url after deconding it.
Constraints:
1 <= url.length <= 104
url
is guranteed to be a valid URL.
Companies:
Microsoft
Related Topics:
Hash Table, String, Design, Hash Function
// OJ: https://leetcode.com/problems/encode-and-decode-tinyurl/
// Author: github.com/lzl124631x
// Time: O(S) for all
// Space: O(N)
const string origin = "http://tinyurl.com";
class Solution {
private:
unordered_map<int, string> m;
int i = 0;
public:
string encode(string longUrl) {
m[i] = longUrl;
return origin + to_string(i++);
}
string decode(string shortUrl) {
return m[stoi(shortUrl.substr(origin.size()))];
}
};
-
The range of URLs that can be decoded is limited by the range of
int
. -
If excessively large number of URLs have to be encoded, after the range of
int
is exceeded, integer overflow could lead to overwriting the previous URLs' encodings, leading to the performance degradation. -
The length of the URL isn't necessarily shorter than the incoming
longURL
. It is only dependent on the relative order in which the URLs are encoded. -
One problem with this method is that it is very easy to predict the next code generated, since the pattern can be detected by generating a few encoded URLs.
// OJ: https://leetcode.com/problems/encode-and-decode-tinyurl/
// Author: github.com/lzl124631x
// Time: O(S) for all
// Space: O(N)
const string origin = "http://tinyurl.com";
const string chars = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
class Solution {
private:
unordered_map<string, string> m;
int i = 1;
string getKey() {
int tmp = i;
string key;
while (tmp > 0) {
tmp--;
key += tmp % chars.size();
tmp /= chars.size();
}
return key;
}
public:
string encode(string longUrl) {
string key = getKey();
m[key] = longUrl;
i++;
return origin + key;
}
string decode(string shortUrl) {
return m[shortUrl.substr(origin.size())];
}
};
-
The number of URLs that can be encoded is, again, dependent on the range of
int
, since, the same countcount will be generated after overflow of integers. -
The length of the encoded URLs isn't necessarily short, but is to some extent dependent on the order in which the incoming
longURL
's are encountered. For example, the codes generated will have the lengths in the following order: 1(62 times), 2(62 * 62 times) and so on. -
The performance is quite good, since the same code will be repeated only after the integer overflow limit, which is quite large.
-
In this case also, the next code generated could be predicted by the use of some calculations.