freeCodeCamp solutions

GH Pages Deploy Heroku GitHub stars

This repo contains my final projects solutions for web-related courses I've done on freeCodeCamp in 2021.

Table of contents

Course

JavaScript Algorithms and Data Structures

This is easy if since I already have some experience with LeetCode, just need to get a bit more familiar with data structure in JS. Thankfully, JS has strong support for functional programming.

Responsive Web Design

The course is very helpful, I learned many things: Flex Box, Grid, media query...

Except the Documentation page (Markdown Guide), other 4 projects is hand-written HTML, CSS and JS. It feels a bit weird to do that in 2021, when there are too many JS frameworks available. But on the other hand, it feels cool to finally able to build such sites.

Task Site
Build a Tribute Page ./web/tribute
Build a Survey Form ./web/survey
Build a Product Landing Page ./web/landing
Build a Technical Documentation Page ./web/doc
Build a Personal Portfolio Webpage ./web/portfolio

Data Visualization

d3 is awesome! I don't know how many times I have that thought when working on this cert. There's a lot of things in and behind it. No wonder why there's so many books on d3. I will definitely use it for my other (real) data visualization projects.

Beside many things I've tried with these projects, I feel like my code for iterate through data and rendering the chart is not efficient. I need to learn more about JS performance. The code could also be structured better.

Task Site
Visualize Data with a Bar Char ./d3/bar
Visualize Data with a Scatterplot Graph ./d3/scatterplot
Visualize Data with a Heat Map ./d3/heat
Visualize Data with a Choropleth Map ./d3/choropleth
Visualize Data with a Treemap Diagram ./d3/treemap

Scientific Computing with Python

Task Code (on Github)
Arithmetic Formatter arithmetic_arranger.py
Time Calculator time_calculator.py
Budget App budget.py
Polygon Area Calculator shape_calculator.py
Probability Calculator prob_calculator.py

Data Analysis with Python

There's a lot of things to I've yet to learn. Don't count on my data analysis skill with Pandas, Numpy, ... I think I'm just good at reading documents and guessing.

Off topic, I used to try Jupyter when it first came out, and used to think about seriously learn Data Analysis. However, I couldn't edit code on the web interface (because of Vim, but I'm not complain), so I drop that thought. I can't understand why web editing become so popular now. Perhaps many people are OK inefficient workflows.

Task Site
Mean-Variance-Standard Deviation Calculator ./pyda/mean-var-std/
Demographic Data Analyzer ./pyda/demographic
Medical Data Visualizer ./pyda/plot
Page View Time Series Visualizer ./pyda/time
Sea Level Predictor ./pyda/sea

APIs and Microservices

This and other courses need a backend require more setup. So I build a small Express app to serve all of them on Heroku.

In order to do that, I had to modify some files that's suppose to not modified, remove the app = express() and expose express.Router(). See the main app code and some custom middleware in heroku folder

The setup works quite well for passing the courses quickly, but I'm not happy with its performance. I've tried stress test the dummy GET /, implement buffered logging and use cluster to run it with multi cores. If you know any good resources or see any of my mistakes, I'm eager to learn.

Task Note Site
Timestamp Microservice ./microservices/timestamp timestamp
Request Header Parser Microservice ./microservices/who who
URL Shortener Microservice ./microservices/short short
Exercise Tracker ./microservices/tracker tracker
File Metadata Microservice ./microservices/file file

Quality assurance

For this course, honestly I'm not interested in the final projects. I like unit test, but I really hate this combination:

As a result of such bad feelings, I have to do my best to get rid of those projects as quickly as possible, including writing dummy tests in some of below projects to pass the FCC tests. Sorry.

Task Note Site
Metric-Imperial Converter ./qa/converter converter
Issue Tracker ./qa/tracker tracker
Personal Library ./qa/lib lib
Sudoku Solver ./qa/sudoku sudoku
American British Translator ./qa/translator translator

Information Security

Task Note Site
Stock Price Checker ./infosec/stonk stonk
Anonymous Message Board ./infosec/bulletin-board bulletin-board
Port Scanner ./infosec/portscan Code
SHA-1 Password Cracker ./infosec/pwcracker Code
Secure Real Time Multiplayer Game ./infosec/game game (unfinished)

Machine Learning with Python

See its note here

Task Site
Rock Paper Scissors ./ai/rps
Cat and Dog Image Classifier ./ai/cv
Book Recommendation Engine using K ./ai/recommendation
Linear Regression Health Costs Calculator ./ai/linear_regression
Neural Network SMS Text Classifier ./ai/nn

Coding Interview Prep

This doesn't have a cert, but I still do it to understand more about JS. See here for the notes and some solutions.

Front End Development Libraries

Task Site Time Lib
Build a Random Quote Machine ./fe/quote 4h React
Build a Markdown Previewer ./fe/markdown 4h Vue
Build a Drum Machine ./fe/drum 3h Svelte
Build a JavaScript Calculator ./fe/calc 3h (none)
Build a 25 + 5 Clock ./fe/clock 4h React

Note: