Skip to content

Algorithms Exercises solved in C++17, running with CMake and Catch2 unittest framework. Developed with TDD.

License

Notifications You must be signed in to change notification settings

sir-gon/algorithm-exercises-cpp

Repository files navigation

Algorithm Exercises (C++17)

C++17 CI CppCheck Lint Markdown Lint YAML lint

GitHub GitHub language count GitHub top language CodeFactor codecov

TL;DR

Algorithms Exercises solved in C++17, running with Catch2 testing suite throug CMake. Developed with TDD.

What is this?

This repository is part of a series that share and solve the same objectives, with the difference that each one is based on a different software ecosystem, depending on the chosen programming language:

Objetives

Functional

  • For academic purposes, it is an backup of some algorithm exercises (with their solutions), proposed by various sources: leetcode, hackerrank, projecteuler, ...

  • The solutions must be written on "vanilla code", that is, avoiding as much as possible the use of external libraries (in runtime).

  • Adoption of methodology and good practices. Each exercise is implemented as a unit test set, using TDD (Test-driven Development) and Clean Code ideas.

Install and Run

Install and Run directly

Using a NodeJS runtime in your SO. You must install dependencies:

cd build
cmake ..
make
make test

About development

cmake --version
cmake version 3.30.3

CMake suite maintained and supported by Kitware (kitware.com/cmake).
g++ --version
Apple clang version 15.0.0 (clang-1500.3.9.4)
Target: x86_64-apple-darwin23.6.0
Thread model: posix
InstalledDir: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin
brew info catch2
==> catch2: stable 3.7.0 (bottled)
Modern, C++-native, header-only, test framework
https://github.com/catchorg/Catch2
Installed
/usr/local/Cellar/catch2/3.7.0 (230 files, 2.7MB) *
  Poured from bottle using the formulae.brew.sh API on 2024-09-08 at 19:35:03
From: https://github.com/Homebrew/homebrew-core/blob/HEAD/Formula/c/catch2.rb
License: BSL-1.0
==> Dependencies
Build: cmake ✘
==> Analytics
install: 602 (30 days), 1,327 (90 days), 5,032 (365 days)
install-on-request: 561 (30 days), 1,232 (90 days), 4,619 (365 days)
build-error: 0 (30 days)

Algorithm excersices sources

  • Leetcode online platform for coding interview preparation.
  • HackerRank competitive programming challenges for both consumers and businesses.
  • Project Euler a series of computational problems intended to be solved with computer programs.

Use these answers to learn some tip and tricks for algorithms tests.

Disclaimer. Why I publish solutions?

As Project Euler says:

https://projecteuler.net/about#publish

I learned so much solving problem XXX, so is it okay to publish my solution elsewhere?
It appears that you have answered your own question. There is nothing quite like that "Aha!" moment when you finally beat a problem which you have been working on for some time. It is often through the best of intentions in wishing to share our insights so that others can enjoy that moment too. Sadly, that will rarely be the case for your readers. Real learning is an active process and seeing how it is done is a long way from experiencing that epiphany of discovery. Please do not deny others what you have so richly valued yourself.

However, the rule about sharing solutions outside of Project Euler does not apply to the first one-hundred problems, as long as any discussion clearly aims to instruct methods, not just provide answers, and does not directly threaten to undermine the enjoyment of solving later problems. Problems 1 to 100 provide a wealth of helpful introductory teaching material and if you are able to respect our requirements, then we give permission for those problems and their solutions to be discussed elsewhere.

If you have better answers or optimal solutions, fork and PR-me

Enjoy 😁 !