From 51109a5e84bc635dabe896eeafbca10909db095c Mon Sep 17 00:00:00 2001 From: Paulo Custodio Date: Sun, 27 Jun 2021 14:47:40 +0100 Subject: Add C and C++ solutions to challenge 011 --- challenge-011/paulo-custodio/cpp/ch-2.cpp | 49 +++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 challenge-011/paulo-custodio/cpp/ch-2.cpp (limited to 'challenge-011/paulo-custodio/cpp/ch-2.cpp') diff --git a/challenge-011/paulo-custodio/cpp/ch-2.cpp b/challenge-011/paulo-custodio/cpp/ch-2.cpp new file mode 100644 index 0000000000..d2847da6ec --- /dev/null +++ b/challenge-011/paulo-custodio/cpp/ch-2.cpp @@ -0,0 +1,49 @@ +/* +Challenge 011 + +Challenge #2 +Write a script to create an Indentity Matrix for the given size. For example, +if the size is 4, then create Identity Matrix 4x4. For more information about +Indentity Matrix, please read the wiki page. +*/ + +#include +#include +using namespace std; + +vector> identity_matrix(int n) { + vector> id; + for (int row = 0; row < n; row++) { + id.push_back({}); + for (int col = 0; col < n; col++) + id[row].push_back(col == row ? 1 : 0); + } + return id; +} + +void print_matrix(ostream& os, vector>& m) { + os << "["; + const char* row_sep = ""; + for (size_t row = 0; row < m.size(); row++) { + os << row_sep << "["; + row_sep = ",\n "; + const char* col_sep = ""; + for (size_t col = 0; col < m[row].size(); col++) { + os << col_sep << m[row][col]; + col_sep = ", "; + } + os << "]"; + } + os << "]\n"; +} + +int main(int argc, char* argv[]) { + int n = 0; + if (argc == 2) + n = atoi(argv[1]); + if (n < 1) + n = 4; + + vector> id = identity_matrix(n); + print_matrix(cout, id); +} -- cgit