私は異なる3文字の単語の文字列を持っています:
catdogmattabratliematdogatt
それぞれの単語にアルファベットを割り当て、最後の文字列を印刷する必要があります。
cat: P, dog: A, mat: T, tab: I, rat: E, lie: O, att: L
したがって、私の出力は次のようになります。
PATIEOTAL
switchステートメントを使用してみましたが、3文字を同時に入力できません。
amap<string, char>
を使用して次のことを行います。
map<string, char> wordToChar;
// Load wordToChar appropriately; c++11 you can use an initializer list for simplicity
for (int i = 0; i < strLen; i += 3)
{
string str;
str.push_back(theString[i]);
str.push_back(theString[i+1]);
str.push_back(theString[i+2]);
cout << wordToChar[theString] << endl;
}
char
-ステートメントで3つ使用できるようswitch
です!それは私だけではなく、「多文字リテラル」と呼ばれる標準機能でもあります(2.14.3 [lex.ccon]段落1を参照してください。これらの獣の種類はですint
)。このハックを使用するようにアドバイスするわけではありませんが、システムのエンディアンによっては計算で文字を逆にする必要がある場合がありますが、機能します(詳細はわかりません)。完全な例を次に示します(ただし、入力では、分離する必要のある1つの文字列ではなく、個別の単語が必要です)。
#include <iostream>
#include <string.h>
int main(int ac, char* av[])
{
typedef unsigned char u;
for (int i(1); i != ac; ++i) {
if (strlen(av[i]) == 3)
{
std::cout << std::hex;
int value(u(av[i][2])
+ 256u * (u(av[i][1])
+ 256u * u(av[i][0])));
switch (value) {
default:
std::cout << "option not found!: '" << av[i] << "'\n";
break;
case 'cat': std::cout << 'P'; break;
case 'dog': std::cout << 'A'; break;
case 'mat': std::cout << 'T'; break;
case 'tab': std::cout << 'I'; break;
case 'rat': std::cout << 'E'; break;
case 'lie': std::cout << 'O'; break;
case 'att': std::cout << 'L'; break;
}
}
}
std::cout << '\n';
}
switchステートメントの使用について質問されたので、3文字の単語とそれに対応する文字のハードコードされたリストがあれば問題ないと思います。その場合、それぞれが3文字の単語の文字と一致しようとする一連のif-then-elseステートメントを使用して、この問題を解決します。または、ネストされたswitchステートメントを使用することもできますが、構文により、そのソリューションはIMOを読み取るのが少し難しくなります。
static char match_word(std::string const &str, std::size_t offset)
{
char ret = '?';
if (str[offset + 0] == 'c' && str[offset + 1] == 'a' && str[offset + 2] == 't') {
ret = 'P';
}
else if (str[offset + 0] == 'd' && str[offset + 1] == 'o' && str[offset + 2] == 'g') {
ret = 'A';
}
else if (str[offset + 0] == 'm' && str[offset + 1] == 'a' && str[offset + 2] == 't') {
ret = 'T';
}
else if (str[offset + 0] == 't' && str[offset + 1] == 'a' && str[offset + 2] == 'b') {
ret = 'I';
}
else if (str[offset + 0] == 'r' && str[offset + 1] == 'a' && str[offset + 2] == 't') {
ret = 'E';
}
else if (str[offset + 0] == 'l' && str[offset + 1] == 'i' && str[offset + 2] == 'e') {
ret = 'O';
}
else if (str[offset + 0] == 'a' && str[offset + 1] == 't' && str[offset + 2] == 't') {
ret = 'L';
}
return ret;
}
次に、次のような単純なmain関数を使用してコードをテストできます。
int main(int argc, char **argv)
{
if (argc != 2) {
std::cerr << "USAGE: " << argv[0] << " ENCODED" << std::endl;
return 1;
}
else {
std::string example(argv[1]);
for (std::size_t idx = 0; idx < example.size(); idx += 3) {
std::cout << match_word(example, idx);
}
std::cout << std::endl;
return 0;
}
}
次に、エンコードされた文字列を次のような唯一の引数としてプログラムを実行します。
$ ./a.out catdogmattabratliematdogatt
PATIEOTAL