aboutsummaryrefslogtreecommitdiff
path: root/challenge-191/deadmarshal/cpp/ch-2.cpp
diff options
context:
space:
mode:
authordeadmarshal <adeadmarshal@gmail.com>2022-11-20 10:46:28 +0330
committerdeadmarshal <adeadmarshal@gmail.com>2022-11-20 10:46:28 +0330
commit4a6109910c67852630b4d5b50d2a1bf465cfbeaa (patch)
tree6e42048916f594d7761bf110717780a31e556b05 /challenge-191/deadmarshal/cpp/ch-2.cpp
parentbde0adaf7b8dfe99c4e494c932d8702eb8cf9a56 (diff)
downloadperlweeklychallenge-club-4a6109910c67852630b4d5b50d2a1bf465cfbeaa.tar.gz
perlweeklychallenge-club-4a6109910c67852630b4d5b50d2a1bf465cfbeaa.tar.bz2
perlweeklychallenge-club-4a6109910c67852630b4d5b50d2a1bf465cfbeaa.zip
Challenge191
Diffstat (limited to 'challenge-191/deadmarshal/cpp/ch-2.cpp')
-rw-r--r--challenge-191/deadmarshal/cpp/ch-2.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/challenge-191/deadmarshal/cpp/ch-2.cpp b/challenge-191/deadmarshal/cpp/ch-2.cpp
new file mode 100644
index 0000000000..9af54816b1
--- /dev/null
+++ b/challenge-191/deadmarshal/cpp/ch-2.cpp
@@ -0,0 +1,34 @@
+#include<iostream>
+#include<vector>
+
+bool is_cute(const std::vector<int>& vec)
+{
+ for(std::size_t i = 1; i <= vec.size(); ++i)
+ if((i % vec[i-1]) && (vec[i-1] % i)) return false;
+ return true;
+}
+
+void permute(std::vector<int>& vec, int i, std::size_t sz, int *count)
+{
+ if(sz == i)
+ {
+ if(is_cute(vec)) (*count)++;
+ return;
+ }
+ for(std::size_t j = i; j < sz; ++j)
+ {
+ std::swap(vec[i], vec[j]);
+ permute(vec,i+1,sz,count);
+ std::swap(vec[i], vec[j]);
+ }
+ return;
+}
+
+int main()
+{
+ std::vector<int> vec{1,2};
+ int count{};
+ permute(vec,0,2,&count);
+ std::cout << count << '\n';
+ return 0;
+}