-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathEnDecodeURL.cpp
More file actions
50 lines (40 loc) · 1.85 KB
/
EnDecodeURL.cpp
File metadata and controls
50 lines (40 loc) · 1.85 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/*
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 given longUrl.
String decode(String shortUrl) Returns the original long URL for the given shortUrl. It is guaranteed that the given shortUrl 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.
*/
class Solution {
public:
unordered_map<string, string> codeDB, urlDB;
const string chars="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
string getCode() {
string code = "";
for (int i = 0; i < 6; i++) code += chars[rand() % 62];
return "http://tinyurl.com/" + code;
}
string encode(string longUrl)
{
if (urlDB.find(longUrl) != urlDB.end()) return urlDB[longUrl];
string code = getCode();
while (codeDB.find(code) != codeDB.end()) code = getCode();
codeDB[code] = longUrl;
urlDB[longUrl] = code;
return code;
}
string decode(string shortUrl) {
return codeDB[shortUrl];
}
};
// Your Solution object will be instantiated and called as such:
// Solution solution;
// solution.decode(solution.encode(url));