文字列の行を読み取り、それがミラーリング、パリンドローム、またはミラーリングされたパリンドロームであるかどうかを確認するコードを書いています。問題は、最後の値を除いて、入力に対して常に間違った値が表示されることです。
サンプル入力:
NOTAPALINDROME
ISAPALINILAPASI
2A3MEAS
ATOYOTA
コード:
#include<iostream>
#include<string>
#include<vector>
using namespace std;
bool is_palindrome(const string &s)
{
for(int i=0,j=s.length()-1;i!=j;i++,j--)
{
if(s[i]!=s[j])
return false;
}
return true;
}
char get_mirror(const char &c)
{
switch(c)
{
case 'A':return c;
case 'E':return '3';
case 'H':return c;
case 'I':return c;
case 'J':return 'L';
case'L':return 'J';
case'M':return c;
case 'O':return c;
case 'S':return '2';
case 'T':return c;
case'U':return c;
case'W':return c;
case'X':return c;
case'Y':return c;
case'Z':return '5';
case'1':return c;
case'2':return 'S';
case'3':return 'E';
case'5':return 'Z';
case'8':return c;
default: return'-1';
}
}
bool is_mirrored(const string &s)
{
for(int i=0,j=s.length()-1;i!=j;i++,j--)
{
if(get_mirror(s[i])!=s[j])
{
return false;
}
}
return true;
}
int main()
{
vector<string>cases;
vector<string>::iterator pt;
string temp;
while(getline(cin,temp))
{
cases.push_back(temp);
}
for(pt=cases.begin();pt!=cases.end();pt++)
{
cout<<*pt<<" "<<is_palindrome(*pt)<<" "<<is_mirrored(*pt)<<endl;
}
system("pause");
return 0;
}
文字列が多い場合に出力:
NOTAPALINDROME
ISAPALINILAPASI
2A3MEAS
ATOYOTA
^Z
NOTAPALINDROME 0 0
ISAPALINILAPASI 0 0
2A3MEAS 0 0
ATOYOTA 1 1
Press any key to continue . . .
1つの文字列の場合に出力:
2A3MEAS
^Z
2A3MEAS 0 1
Press any key to continue . . .