#include <iostream>
#include <algorithm>
#include <iomanip>
#include <vector>
#include <string>
#include <unordered_map>
using namespace std;
class Time
{
private :
int hour;
int minute;
int second;
string midday;
public :
Time( )
{
}
Time( int h, int m, int s)
{
hour = h;
minute = m;
second = s;
}
void setHour( int h)
{
if ( h >= 0 && h <= 24 )
{
if ( h == 24 )
{
hour = 0 ;
midday = "AM" ;
}
else if ( h > 12 )
{
hour = h - 12 ;
midday = "PM" ;
}
else if ( h == 0 )
{
hour = 12 ;
midday = "AM" ;
}
else if ( h == 12 )
{
hour = h;
midday = "PM" ;
}
else
{
hour = h;
midday = "AM" ;
}
}
}
string getmidday( )
{
return midday;
}
int getHour( )
{
return hour;
}
void setMinute( int m)
{
if ( m >= 0 && m <= 59 )
{
minute = m;
}
else
{
minute = 0 ;
}
}
int getMinute( )
{
return minute;
}
void setSecond( int s)
{
if ( s >= 0 && s <= 59 )
{
second = s;
}
else
{
second = 0 ;
}
}
int getSecond( )
{
return second;
}
void printTime_info( )
{
cout << " the time is " << setfill( '0' ) << setw( 2 ) << hour << ":" ;
cout << setfill( '0' ) << setw( 2 ) << minute << ":" ;
cout << setfill( '0' ) << setw( 2 ) << second << " " << midday << endl;
}
} ;
class Country
{
Time timezone;
bool found;
string stadt;
unordered_map< string, int > country = {
{ "afghanistan" , 4 } , { "alaska" , - 9 } , { "argentina" , - 3 } , { "armenia" , 4 } , { "azores" , - 1 } ,
{ "bangladesh" , 6 } , { "bhutan" , 6 } , { "brasilia" , - 3 } , { "brazil" , - 3 } , { "cambodia" , 7 } ,
{ "canada" , - 5 } , { "cape verde island" , - 1 } , { "caracas" , - 4 } , { "central america" , - 6 } , { "chihuahua" , - 7 } ,
{ "china" , 8 } , { "colombia" , - 5 } , { "cuba" , - 5 } , { "egypt" , 2 } , { "fiji" , 12 } ,
{ "france" , 1 } , { "georgia" , 4 } , { "germany" , 1 } , { "ghana" , 0 } , { "greece" , 2 } ,
{ "greenland" , - 3 } , { "guam" , 10 } , { "hawaii" , - 10 } , { "iceland" , 0 } , { "india" , 5 } ,
{ "indonesia" , 7 } , { "iran" , 3 } , { "iraq" , 3 } , { "italy" , 1 } , { "jakarta" , 7 } ,
{ "japan" , 9 } , { "kazakhstan" , 5 } , { "kenya" , 3 } , { "korea" , 9 } , { "kuwait" , 3 } ,
{ "la paz" , - 4 } , { "mali" , 0 } , { "malaysia" , 8 } , { "marshall island" , 12 } , { "mazatlan" , - 7 } ,
{ "melbourne" , 10 } , { "mexico" , - 6 } , { "midway island" , - 11 } , { "moscow" , 3 } , { "myanmar" , 6 } ,
{ "nepal" , 5 } , { "new zealand" , 12 } , { "newfoundland" , - 3 } , { "nigeria" , 1 } , { "oman" , 4 } ,
{ "pakistan" , 5 } , { "peru" , - 5 } , { "philippines" , 8 } , { "poland" , 1 } , { "rio" , - 3 } ,
{ "russia" , 3 } , { "samoa" , - 11 } , { "santiago" , - 4 } , { "saudi arabia" , 3 } , { "senegal" , 0 } ,
{ "singapore" , 8 } , { "solomon island" , 11 } , { "south africa" , 2 } , { "south korea" , 9 } , { "spain" , 1 } ,
{ "sri lanka" , 5 } , { "sweden" , 1 } , { "sydney" , 10 } , { "thailand" , 7 } , { "tijuana" , - 8 } ,
{ "turkey" , 3 } , { "ukraine" , 2 } , { "united arab emirates" , 4 } , { "united kingdom" , 0 } , { "united states" , - 5 } ,
{ "uzbekistan" , 5 } , { "vanuatu" , 11 } , { "vietnam" , 7 } , { "vladivostok" , 10 } } ;
int Levenstein_Distance( const string & word1, const string & word2)
{
int m = word1.length ( ) ;
int n = word2.length ( ) ;
vector< vector < int >> dif( m + 1 , vector< int > ( n+ 1 ) ) ;
for ( int i = 0 ; i <= m; i++ )
{
dif[ i] [ 0 ] = i;
}
for ( int j = 0 ; j <= n; j++ )
{
dif[ 0 ] [ j] = j;
}
for ( int i = 1 ; i <= m; i++ )
{
for ( int j = 1 ; j <= n; j++ )
{
if ( word1[ i - 1 ] == word2[ j- 1 ] )
{
dif[ i] [ j] = dif[ i- 1 ] [ j- 1 ] ;
}
else {
dif[ i] [ j] = min( { dif[ i- 1 ] [ j- 1 ] + 1 , /// substitute
dif[ i- 1 ] [ j] + 1 , /// deletion
dif[ i] [ j- 1 ] + 1 } ) ; /// insertation
}
}
}
return dif[ m] [ n] ;
}
public :
Country( ) : found( false ) { }
void setTimeLine( string paese, Time UTC)
{
for ( int i = 0 ; i < paese.size ( ) ; i++ )
{
if ( paese[ i] >= 'A' && paese[ i] <= 'Z' )
{
paese[ i] = paese[ i] + 32 ;
}
}
int min_distance = 100 ;
string best_match;
for ( auto it = country.begin ( ) ; it ! = country.end ( ) ; it++ )
{
int distance = Levenstein_Distance( paese,it- > first) ;
if ( distance == 0 )
{
found = true ;
best_match = it- > first;
break ;
}
else if ( distance < min_distance)
{
min_distance = distance;
best_match = it- > first;
}
}
if ( min_distance <= 2 )
{
auto it = country.find ( best_match) ;
found = true ;
stadt = best_match;
int hour = it- > second;
int newHour = UTC.getHour ( ) + hour;
timezone = UTC;
timezone.setHour ( newHour) ;
}
else
{
cout << " Not valid country name" << endl;
found = false ;
}
}
string getCountry( )
{
return stadt;
}
Time gettimeZone( )
{
return timezone;
}
void printnewTime( )
{
if ( found == true )
{
cout << " the local time in " << stadt << " is " << setfill( '0' ) << setw( 2 ) << timezone.getHour ( ) << ":" ;
cout << setfill( '0' ) << setw( 2 ) << timezone.getMinute ( ) << ":" ;
cout << setfill( '0' ) << setw( 2 ) << timezone.getSecond ( ) << " " << timezone.getmidday ( ) << endl;
cout << endl;
cout << "A fun fact: Airplane travelers can be considered time travelers since they journey through both space and time." << endl;
}
else {
return ;
}
}
} ;
int main( )
{
// int ora, minu, secondo;
//
// cout << "what's the time now in your country" << endl;
// cout << endl;
// cout << "enter hour then minutes then second" << endl;
//
// cin >> ora >> minu >> secondo;
//
// Time zone1(ora,minu,secondo);
//
Country c;
//
// cout << "enter the city that you are traveling to: ";
// string city;
//
// cin.ignore();
//
// getline(cin,city);
// cout<<endl;
//
//
// c.setTimeLine(city,zone1);
// c.printnewTime();
// cout<<endl;
//
// cout<<endl;
Time t1( 20 ,30 ,0 ) ;
c.setTimeLine ( "itly" , t1) ; // Should auto-correct to "italy"
c.printnewTime ( ) ;
cout << endl;
Time t2( 10 ,0 ,0 ) ;
c.setTimeLine ( "z" , t2) ;
c.printnewTime ( ) ;
cout << endl;
return 0 ;
}
#include <iostream>
#include <algorithm>
#include <iomanip>
#include <vector>
#include <string>
#include <unordered_map>

using namespace std;

class Time
{
private:
    int hour;
    int minute;
    int second;
    string midday;

public:

    Time()
    {
    }

    Time(int h, int m, int s)
    {
        hour = h;
        minute = m;
        second = s;

    }

    void setHour(int h)
    {
        if (h >= 0 && h <= 24)
        {
            if (h == 24)
            {
                hour = 0;
                midday = "AM";
            }
            else if (h > 12)
            {
                hour = h - 12;
                midday = "PM";

            }
            else if (h == 0)
            {
                hour = 12;
                midday = "AM";
            }
            else if (h == 12)
            {
                hour = h;
                midday = "PM";
            }

            else
            {
                hour = h;
                midday = "AM";
            }
        }
    }

    string getmidday()
    {
        return midday;
    }

    int getHour()
    {
        return hour;
    }

    void setMinute(int m)
    {
        if (m >= 0 && m <= 59)
        {
            minute = m;
        }
        else
        {
            minute = 0;
        }
    }

    int getMinute()
    {
        return minute;
    }

    void setSecond(int s)
    {
        if (s >= 0 && s <= 59)
        {
            second = s;
        }
        else
        {
            second = 0;
        }
    }

    int getSecond()
    {
        return second;
    }

    void printTime_info()
    {
        cout << " the time is " << setfill('0') << setw(2) << hour << ":";
        cout << setfill('0') << setw(2) << minute << ":";
        cout << setfill('0') << setw(2) << second << " " << midday << endl;
    }

};


class Country
{
    Time timezone;

    bool found;

    string stadt;

    unordered_map<string, int> country = {
    {"afghanistan", 4}, {"alaska", -9}, {"argentina", -3}, {"armenia", 4}, {"azores", -1},
    {"bangladesh", 6}, {"bhutan", 6}, {"brasilia", -3}, {"brazil", -3}, {"cambodia", 7},
    {"canada", -5}, {"cape verde island", -1}, {"caracas", -4}, {"central america", -6}, {"chihuahua", -7},
    {"china", 8}, {"colombia", -5}, {"cuba", -5}, {"egypt", 2}, {"fiji", 12},
    {"france", 1}, {"georgia", 4}, {"germany", 1}, {"ghana", 0}, {"greece", 2},
    {"greenland", -3}, {"guam", 10}, {"hawaii", -10}, {"iceland", 0}, {"india", 5},
    {"indonesia", 7}, {"iran", 3}, {"iraq", 3}, {"italy", 1}, {"jakarta", 7},
    {"japan", 9}, {"kazakhstan", 5}, {"kenya", 3}, {"korea", 9}, {"kuwait", 3},
    {"la paz", -4}, {"mali", 0}, {"malaysia", 8}, {"marshall island", 12}, {"mazatlan", -7},
    {"melbourne", 10}, {"mexico", -6}, {"midway island", -11}, {"moscow", 3}, {"myanmar", 6},
    {"nepal", 5}, {"new zealand", 12}, {"newfoundland", -3}, {"nigeria", 1}, {"oman", 4},
    {"pakistan", 5}, {"peru", -5}, {"philippines", 8}, {"poland", 1}, {"rio", -3},
    {"russia", 3}, {"samoa", -11}, {"santiago", -4}, {"saudi arabia", 3}, {"senegal", 0},
    {"singapore", 8}, {"solomon island", 11}, {"south africa", 2}, {"south korea", 9}, {"spain", 1},
    {"sri lanka", 5}, {"sweden", 1}, {"sydney", 10}, {"thailand", 7}, {"tijuana", -8},
    {"turkey", 3}, {"ukraine", 2}, {"united arab emirates", 4}, {"united kingdom", 0}, {"united states", -5},
    {"uzbekistan", 5}, {"vanuatu", 11}, {"vietnam", 7}, {"vladivostok", 10}};

int Levenstein_Distance(const string &word1, const string &word2)
    {
        int m = word1.length();
        int n = word2.length();

       vector< vector < int>> dif(m +1, vector<int> (n+1));

       for( int i = 0; i <= m; i++)
       {
           dif[i][0] = i;
       }

       for(int j = 0; j <= n; j++)
       {
           dif[0][j] = j;
       }

        for( int i = 1; i <= m; i++)
       {
            for(int j = 1; j <= n; j++)
       {
           if(word1[i - 1] == word2[j-1])
           {
               dif[i][j] = dif[i-1][j-1];
           }
           else{

             dif[i][j] = min({dif[i-1][j-1]+1, /// substitute
                             dif[i-1][j]+1,   /// deletion
                             dif[i][j-1]+1});  /// insertation
           }
       }
    }
           return dif[m][n];
    }

public:

    Country(): found(false){}

    void setTimeLine(string paese, Time UTC)
    {
        for (int i = 0; i < paese.size(); i++)
        {
            if (paese[i] >= 'A' && paese[i] <= 'Z')
            {
                paese[i] = paese[i] + 32;
            }
        }

        int min_distance = 100;
        string best_match;

     for( auto it = country.begin(); it != country.end(); it++)
      {
        int distance = Levenstein_Distance(paese,it->first);

        if (distance == 0)
        {
            found = true;
            best_match = it->first;
            break;
        }

         else if (distance < min_distance)
            {
             min_distance = distance;
             best_match = it->first;
            }
      }

     if (min_distance <= 2)
          {
            auto it = country.find(best_match);
            found = true;
            stadt = best_match;
            int hour = it->second;
            int newHour = UTC.getHour()+hour;
            timezone = UTC;
            timezone.setHour(newHour);
          }

        else
        {
            cout << " Not valid country name" << endl;
            found = false;
        }
}

    string getCountry()
    {
        return stadt;
    }


    Time gettimeZone()
    {
        return timezone;
    }


        void printnewTime()
        {
            if(found == true)
            {
            cout << " the local time in " << stadt << " is " << setfill('0') << setw(2) << timezone.getHour() << ":";
            cout << setfill('0') << setw(2) << timezone.getMinute() << ":";
            cout << setfill('0') << setw(2) << timezone.getSecond() << " " << timezone.getmidday() << endl;

              cout<<endl;

              cout<< "A fun fact: Airplane travelers can be considered time travelers since they journey through both space and time."<<endl;
            }

            else{

               return;
            }
        }
};

int main()
{

//    int ora, minu, secondo;
//
//    cout << "what's the time now in your country" << endl;
//    cout << endl;
//    cout << "enter hour then minutes then second" << endl;
//
//    cin >> ora >> minu >> secondo;
//
//    Time zone1(ora,minu,secondo);
//
    Country c;
//
//    cout << "enter the city that you are traveling to: ";
//    string city;
//
//    cin.ignore();
//
//    getline(cin,city);
//     cout<<endl;
//
//
//     c.setTimeLine(city,zone1);
//    c.printnewTime();

//    cout<<endl;
//
//        cout<<endl;

        Time t1(20,30,0);
    c.setTimeLine("itly", t1); // Should auto-correct to "italy"
    c.printnewTime();

        cout<<endl;

        Time t2(10,0,0);

    c.setTimeLine("z", t2);
    c.printnewTime();

        cout<<endl;


    return 0;
}
