Notepad/enter/Coding Tips (Classical)/Terminal Tips/2. CLI Tools/Languages/Low level - Back-end/C++.md

2.8 KiB

C++

C++ is one of the most used languages out there for writing low-level code. There are various applications and projects based off of C++.

  • A URL shortener in C++
/**
 * URL shortener Base-62 encoder / decoder C++ Proof-of-Concept.
 *
 * Created as a resource for https://stackoverflow.com/a/742047/293064.
 *
 * How to compile:
 *
 *     g++ -o base64-url-shortener-poc base64-url-shortener-poc.cpp
 *
 * Usage:
 *
 *     ./base64-url-shortener-poc [ID]
 *
 * Example output:
 *
 *     Input ID: 99592
 *     ---
 *     Generated short URL: z4u
 *     ID decoded from URL: 99592
 *
 * @author Jay Taylor <outtatime@gmail.com>
 *
 * @date 2019-07-08
 *
 */

#include <iostream>
#include <algorithm>
#include <string>
#include <cstdlib>

using namespace std;

/**
 * id_to_short_url takes an input ID and produces a short URL suffix.
 *
 * Base-62 encodes the identifier.
 */
string id_to_short_url(unsigned int n) {
    // Mapping which defines the 62 possible output characters.
    char map[] = "abcdefghijklmnopqrstuvwxyzABCDEF"
                 "GHIJKLMNOPQRSTUVWXYZ0123456789";

    string short_url;

    // Convert given ID to a base-62 number.
    while (n) {
        // Append each character mapped by the remainder.
        short_url.push_back(map[n % 62]);
        n /= 62;
    }

    // Reverse the string to complete the base conversion.
    reverse(short_url.begin(), short_url.end());

    return short_url;
}

/**
 * short_url_to_id converts a short URL into the corresponding ID.
 *
 * Base-62 decodes the input string.
 */
unsigned int short_url_to_id(string short_url) {
    unsigned int id = 0;

    // Base decode conversion logic.
    for (int i = 0; i < short_url.length(); ++i) {
        if ('a' <= short_url[i] && short_url[i] <= 'z') {
            id = id * 62 + short_url[i] - 'a';
        }
        if ('A' <= short_url[i] && short_url[i] <= 'Z') {
            id = id * 62 + short_url[i] - 'A' + 26;
        }
        if ('0' <= short_url[i] && short_url[i] <= '9') {
            id = id * 62 + short_url[i] - '0' + 52;
        }
    }
    return id;
}

int main(int argc, char** argv) {
    if (argc == 1) {
        cerr << "error: missing required parameter: id" << endl;
        return 1;
    }

    unsigned int n = atoi(argv[1]);

    if (n <= 0) {
        cerr << "error: invalid input value, an integer greater than 0 is required" << endl;
        return 1;
    }

    cout << "Input ID: " << n << endl << "---" << endl;

    string encoded_short_url = id_to_short_url(n);
    unsigned int decoded_id = short_url_to_id(encoded_short_url);

    cout << "Generated short URL: " << encoded_short_url << endl;
    cout << "ID decoded from URL: " << decoded_id << endl;
    return 0;
}