feat(c++): cmake
-
This commit is contained in:
parent
1caf1c51be
commit
8c607ab996
3 changed files with 34 additions and 11 deletions
10
languages/c++/CMakeLists.txt
Normal file
10
languages/c++/CMakeLists.txt
Normal 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)
|
|
@ -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);
|
||||||
|
}
|
Loading…
Reference in a new issue