feat(c++): cmake

-
This commit is contained in:
newt 2024-10-09 18:02:42 +01:00
parent 136cd9adf7
commit d0abff8ae9
3 changed files with 34 additions and 11 deletions

View file

@ -0,0 +1,10 @@
cmake_minimum_required(VERSION 3.13)
project(the-honk)
set(CMAKE_CXX_STANDARD 14)
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
add_executable(pascal code/pascal.cc)
add_executable(babylonian code/babylonian.cc)

View file

@ -3,12 +3,12 @@
using namespace std; using namespace std;
// Calculate Pascal's triangle // Calculate Pascal's triangle
vector<vector<int>> pascal(int rowCount) { vector<vector<long long>> pascal(int rowCount) {
vector<vector<int>> rows{{1}}; vector<vector<long long>> rows{{1}};
for (int i = 0; i < rowCount; i++) { for (int i = 0; i < rowCount; i++) {
vector<int> previousRow = rows[rows.size() - 1]; vector<long long> previousRow = rows[rows.size() - 1];
vector<int> newRow{1}; vector<long long> newRow{1};
for (int j = 0; j < previousRow.size() - 1; j++) { for (int j = 0; j < previousRow.size() - 1; j++) {
newRow.push_back(previousRow[j] + previousRow[j + 1]); newRow.push_back(previousRow[j] + previousRow[j + 1]);
@ -21,7 +21,8 @@ vector<vector<int>> pascal(int rowCount) {
return rows; return rows;
} }
int vectorStringLength(vector<int> vector) { // Find the length of a vector if it were outputted as a string with a space between each value
int vectorStringLength(vector<long long> vector) {
int value = vector.size(); int value = vector.size();
for (int i = 0; i < vector.size(); i++) { for (int i = 0; i < vector.size(); i++) {
@ -31,15 +32,18 @@ int vectorStringLength(vector<int> vector) {
return value; return value;
} }
int main() { // Draw Pascal's Triangle
vector<vector<int>> pascalsTriangle = pascal(10); void drawPascalTriangle(int rowCount) {
vector<vector<long long>> pascalsTriangle = pascal(rowCount);
int bottomRowSize = vectorStringLength(pascalsTriangle[pascalsTriangle.size() - 1]); int bottomRowSize = vectorStringLength(pascalsTriangle[pascalsTriangle.size() - 1]);
// Output the triangle for (int i = 0; i < pascalsTriangle.size() - 1; i++) {
for (int i = 0; i < pascalsTriangle.size(); i++) { vector<long long> currentRow = pascalsTriangle[i];
vector<int> currentRow = pascalsTriangle[i];
int rowSize = vectorStringLength(currentRow); int rowSize = vectorStringLength(currentRow);
int sizeDifference = bottomRowSize - rowSize; int sizeDifference = bottomRowSize - rowSize;
string spacing = ""; string spacing = "";
for (int j = 0; j < sizeDifference / 2; j++) { for (int j = 0; j < sizeDifference / 2; j++) {
@ -63,3 +67,12 @@ int main() {
} }
} }
} }
int main() {
cout << "How many rows of Pascal's Triangle would you like to calculate? ";
int rowCount;
cin >> rowCount;
drawPascalTriangle(rowCount);
}