aboutsummaryrefslogtreecommitdiff
path: root/challenge-207/deadmarshal/cpp/ch-1.cpp
diff options
context:
space:
mode:
authorPaulo Custodio <pauloscustodio@gmail.com>2023-03-13 12:37:37 +0000
committerGitHub <noreply@github.com>2023-03-13 12:37:37 +0000
commitd18742a481f56afe01099d0a3252810bfbfef65c (patch)
tree6403921b1f962095cb9cfd42e23228b855302606 /challenge-207/deadmarshal/cpp/ch-1.cpp
parent32d3b1d2c7cc578c4347836715cbc8040cc20afb (diff)
parent733b9428a3c65d35f20504ac9d0122379bad71a9 (diff)
downloadperlweeklychallenge-club-d18742a481f56afe01099d0a3252810bfbfef65c.tar.gz
perlweeklychallenge-club-d18742a481f56afe01099d0a3252810bfbfef65c.tar.bz2
perlweeklychallenge-club-d18742a481f56afe01099d0a3252810bfbfef65c.zip
Merge branch 'manwar:master' into master
Diffstat (limited to 'challenge-207/deadmarshal/cpp/ch-1.cpp')
-rw-r--r--challenge-207/deadmarshal/cpp/ch-1.cpp33
1 files changed, 33 insertions, 0 deletions
diff --git a/challenge-207/deadmarshal/cpp/ch-1.cpp b/challenge-207/deadmarshal/cpp/ch-1.cpp
new file mode 100644
index 0000000000..e778f5824b
--- /dev/null
+++ b/challenge-207/deadmarshal/cpp/ch-1.cpp
@@ -0,0 +1,33 @@
+#include<iostream>
+#include<string>
+#include<vector>
+#include<algorithm>
+
+bool all_match(const std::string &s1, const std::string &s2)
+{
+ for(auto &c : s1) if(s2.find(c) == std::string::npos) return false;
+ return true;
+}
+
+void keyboard_word(std::vector<std::string> &vec)
+{
+ const std::vector<std::string>
+ qwerty{"qwertyuiop","asdfghjkl","zxcvbnm"};
+ for(auto &s : vec)
+ std::transform(s.begin(),s.end(),s.begin(),
+ [](unsigned char c){return std::tolower(c);});
+ for(const auto &q : qwerty)
+ for(const auto &s : vec)
+ if(all_match(s,q)) std::cout << s << ' ';
+ std::cout << '\n';
+}
+
+int main()
+{
+ std::vector<std::string> vec1{"Hello","Alaska","Dad","Peace"},
+ vec2{"OMG","Bye"};
+ keyboard_word(vec1);
+ keyboard_word(vec2);
+ return 0;
+}
+