/**
We have a catalog of song titles (and their lengths) that we play at a local radio station. We have been asked to play two of those songs in a row, and they must add up to exactly seven minutes long.
Given a list of songs and their durations, write a function that returns the names of any two distinct songs that add up to exactly seven minutes. If there is no such pair, return an empty collection.
Example:
song_times_1 = [
("Stairway to Heaven", "8:05"), ("Immigrant Song", "2:27"),
("Rock and Roll", "3:41"), ("Communication Breakdown", "2:29"),
("Good Times Bad Times", "2:48"), ("Hot Dog", "3:19"),
("The Crunge", "3:18"), ("Achilles Last Stand", "10:26"),
("Black Dog", "4:55")
]
find_pair(song_times_1) => ["Rock and Roll", "Hot Dog"] (3:41 + 3:19 = 7:00)
Additional Input:
song_times_2 = [
("Stairway to Heaven", "8:05"), ("Immigrant Song", "2:27"),
("Rock and Roll", "3:41"), ("Communication Breakdown", "2:29"),
("Good Times Bad Times", "2:48"), ("Black Dog", "4:55"),
("The Crunge", "3:18"), ("Achilles Last Stand", "10:26"),
("The Ocean", "4:31"), ("Hot Dog", "3:19"),
]
song_times_3 = [
("Stairway to Heaven", "8:05"), ("Immigrant Song", "2:27"),
("Rock and Roll", "3:41"), ("Communication Breakdown", "2:29"),
("Hey Hey What Can I Do", "4:00"), ("Poor Tom", "3:00"),
("Black Dog", "4:55")
]
song_times_4 = [
("Hey Hey What Can I Do", "4:00"), ("Rock and Roll", "3:41"),
("Communication Breakdown", "2:29"), ("Going to California", "3:30"),
("On The Run", "3:50"), ("The Wrestler", "3:50"),
("Black Mountain Side", "2:11"), ("Brown Eagle", "2:20")
]
song_times_5 = [("Celebration Day", "3:30"), ("Going to California", "3:30")]
song_times_6 = [
("Rock and Roll", "3:41"), ("If I lived here", "3:59"),
("Day and night", "5:03"), ("Tempo song", "1:57")
]
Complexity Variable:
n = number of song/time pairs
All Test Cases - snake_case:
find_pair(song_times_1) => ["Rock and Roll", "Hot Dog"]
find_pair(song_times_2) => ["Rock and Roll", "Hot Dog"] or ["Communication Breakdown", "The Ocean"]
find_pair(song_times_3) => ["Hey Hey What Can I Do", "Poor Tom"]
find_pair(song_times_4) => []
find_pair(song_times_5) => ["Celebration Day", "Going to California"]
find_pair(song_times_6) => ["Day and night", "Tempo song"]
All Test Cases - camelCase:
findPair(songTimes1) => ["Rock and Roll", "Hot Dog"]
findPair(songTimes2) => ["Rock and Roll", "Hot Dog"] or ["Communication Breakdown", "The Ocean"]
findPair(songTimes3) => ["Hey Hey What Can I Do", "Poor Tom"]
findPair(songTimes4) => []
findPair(songTimes5) => ["Celebration Day", "Going to California"]
findPair(songTimes6) => ["Day and night", "Tempo song"]
**/
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
vector< pair< string, int >> convertMinuteToSecond( vector< pair< string, string>> songTimes) {
vector< pair< string, int >> res;
for ( int i= 0 ; i< songTimes.size ( ) ; i++ ) {
pair< string, string> currentSong = songTimes[ i] ;
string duration = currentSong.second ;
cout << duration<< endl;
cout << duration[ 0 ] << endl;
cout << duration[ 2 ] << endl;
cout << duration[ 3 ] << endl;
if ( duration.size ( ) <= 4 ) {
int second = 0 ;
second = ( duration[ 0 ] - '0' ) * 60 ;
second + = ( duration[ 2 ] - '0' ) * 10 ;
second + = duration[ 3 ] - '0' ;
// cout<<currentSong.first<<" "<<second<<endl;
res.push_back ( { currentSong.first , second} ) ;
}
}
return res;
}
vector< string> findSongs( vector< pair< string, string>> songTimes) {
vector< pair< string, int >> songTimesSecond = convertMinuteToSecond( songTimes) ;
cout << endl;
int sevenMinuteInseconds = 420 ;
for ( int i= 0 ; i< songTimesSecond.size ( ) ; i++ ) {
pair< string, int > currentSong = songTimesSecond[ i] ;
// cout<<currentSong.second<<endl;
if ( currentSong.second < sevenMinuteInseconds) {
// cout<<currentSong.first<< " "<<currentSong.second<<endl;
for ( int j= i+ 1 ; j< songTimesSecond.size ( ) ; j++ ) {
// cout<<currentSong.second + songTimesSecond[j].second<<endl;
if ( currentSong.second + songTimesSecond[ j] .second == sevenMinuteInseconds) {
cout << currentSong.first + songTimesSecond[ j] .first << endl;
return { currentSong.first , songTimesSecond[ j] .first } ;
}
}
}
}
return { } ;
}
int main( ) {
const vector< pair< string, string>> songTimes1 = {
{ "Stairway to Heaven" , "8:05" } , { "Immigrant Song" , "2:27" } ,
{ "Rock and Roll" , "3:41" } , { "Communication Breakdown" , "2:29" } ,
{ "Good Times Bad Times" , "2:48" } , { "Hot Dog" , "3:19" } ,
{ "The Crunge" , "3:18" } , { "Achilles Last Stand" , "10:26" } ,
{ "Black Dog" , "4:55" }
} ;
// vector<string> res = findSongs(songTimes1);
// for(int i=0; i<res.size(); i++) {
// cout<<res[i]<<"\t";
// }
cout << endl;
const vector< pair< string, string>> songTimes2 = {
{ "Stairway to Heaven" , "8:05" } , { "Immigrant Song" , "2:27" } ,
{ "Rock and Roll" , "3:41" } , { "Communication Breakdown" , "2:29" } ,
{ "Good Times Bad Times" , "2:48" } , { "Black Dog" , "4:55" } ,
{ "The Crunge" , "3:18" } , { "Achilles Last Stand" , "10:26" } ,
{ "The Ocean" , "4:31" } , { "Hot Dog" , "3:19" }
} ;
const vector< pair< string, string>> songTimes3 = {
{ "Stairway to Heaven" , "8:05" } , { "Immigrant Song" , "2:27" } ,
{ "Rock and Roll" , "3:41" } , { "Communication Breakdown" , "2:29" } ,
{ "Hey Hey What Can I Do" , "4:00" } , { "Poor Tom" , "3:00" } ,
{ "Black Dog" , "4:55" }
} ;
const vector< pair< string, string>> songTimes4 = {
{ "Hey Hey What Can I Do" , "4:00" } , { "Rock and Roll" , "3:41" } ,
{ "Communication Breakdown" , "2:29" } , { "Going to California" , "3:30" } ,
{ "On The Run" , "3:50" } , { "The Wrestler" , "3:50" } ,
{ "Black Mountain Side" , "2:11" } , { "Brown Eagle" , "2:20" }
} ;
const vector< pair< string, string>> songTimes5 = {
{ "Celebration Day" , "3:30" } , { "Going to California" , "3:30" }
} ;
const vector< pair< string, string>> songTimes6 = {
{ "Rock and Roll" , "3:41" } , { "If I lived here" , "3:59" } ,
{ "Day and night" , "5:03" } , { "Tempo song" , "1:57" }
} ;
vector< string> res1 = findSongs( songTimes1) ;
// vector<string> res2 = findSongs(songTimes2);
// vector<string> res3 = findSongs(songTimes3);
// vector<string> res4 = findSongs(songTimes4);
// vector<string> res5 = findSongs(songTimes5);
// vector<string> res6 = findSongs(songTimes6);
return 0 ;
}
/**
We have a catalog of song titles (and their lengths) that we play at a local radio station.  We have been asked to play two of those songs in a row, and they must add up to exactly seven minutes long.  

Given a list of songs and their durations, write a function that returns the names of any two distinct songs that add up to exactly seven minutes.  If there is no such pair, return an empty collection. 

Example:
song_times_1 = [
    ("Stairway to Heaven", "8:05"), ("Immigrant Song", "2:27"),
    ("Rock and Roll", "3:41"), ("Communication Breakdown", "2:29"),
    ("Good Times Bad Times", "2:48"), ("Hot Dog", "3:19"),
    ("The Crunge", "3:18"), ("Achilles Last Stand", "10:26"),
    ("Black Dog", "4:55")
]
find_pair(song_times_1) => ["Rock and Roll", "Hot Dog"] (3:41 + 3:19 = 7:00)

Additional Input:
song_times_2 = [
    ("Stairway to Heaven", "8:05"), ("Immigrant Song", "2:27"),
    ("Rock and Roll", "3:41"), ("Communication Breakdown", "2:29"),
    ("Good Times Bad Times", "2:48"), ("Black Dog", "4:55"),
    ("The Crunge", "3:18"), ("Achilles Last Stand", "10:26"),
    ("The Ocean", "4:31"), ("Hot Dog", "3:19"),
]
song_times_3 = [
    ("Stairway to Heaven", "8:05"), ("Immigrant Song", "2:27"),
    ("Rock and Roll", "3:41"), ("Communication Breakdown", "2:29"),
    ("Hey Hey What Can I Do", "4:00"), ("Poor Tom", "3:00"),
    ("Black Dog", "4:55")
]
song_times_4 = [
    ("Hey Hey What Can I Do", "4:00"), ("Rock and Roll", "3:41"),
    ("Communication Breakdown", "2:29"), ("Going to California", "3:30"),
    ("On The Run", "3:50"), ("The Wrestler", "3:50"), 
    ("Black Mountain Side", "2:11"), ("Brown Eagle", "2:20")
]
song_times_5 = [("Celebration Day", "3:30"), ("Going to California", "3:30")]
song_times_6 = [
  ("Rock and Roll", "3:41"), ("If I lived here", "3:59"),
  ("Day and night", "5:03"), ("Tempo song", "1:57")
]


Complexity Variable:
n = number of song/time pairs

All Test Cases - snake_case:
find_pair(song_times_1) => ["Rock and Roll", "Hot Dog"]
find_pair(song_times_2) => ["Rock and Roll", "Hot Dog"] or ["Communication Breakdown", "The Ocean"]
find_pair(song_times_3) => ["Hey Hey What Can I Do", "Poor Tom"]
find_pair(song_times_4) => []
find_pair(song_times_5) => ["Celebration Day", "Going to California"]
find_pair(song_times_6) => ["Day and night", "Tempo song"]

All Test Cases - camelCase:
findPair(songTimes1) => ["Rock and Roll", "Hot Dog"]
findPair(songTimes2) => ["Rock and Roll", "Hot Dog"] or ["Communication Breakdown", "The Ocean"]
findPair(songTimes3) => ["Hey Hey What Can I Do", "Poor Tom"]
findPair(songTimes4) => []
findPair(songTimes5) => ["Celebration Day", "Going to California"]
findPair(songTimes6) => ["Day and night", "Tempo song"]
**/
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>

using namespace std;

vector<pair<string, int>> convertMinuteToSecond(vector<pair<string, string>> songTimes) {
  vector<pair<string, int>> res;
    for(int i=0; i<songTimes.size(); i++) {
          pair<string, string> currentSong = songTimes[i];
          string duration = currentSong.second;
          cout<<duration<<endl;
          cout<<duration[0]<<endl;
          cout<<duration[2]<<endl;
          cout<<duration[3]<<endl;
          if(duration.size() <= 4) {
            int second = 0;
            second = (duration[0]-'0')*60;
            second += (duration[2]-'0')*10;
            second += duration[3]-'0';

            // cout<<currentSong.first<<" "<<second<<endl;
            res.push_back({currentSong.first, second});
          }
    }
  return res;
}
vector<string> findSongs(vector<pair<string, string>> songTimes) {
  vector<pair<string, int>> songTimesSecond = convertMinuteToSecond(songTimes);
  cout<<endl;
  int sevenMinuteInseconds = 420;
  for(int i=0; i<songTimesSecond.size(); i++) {
    pair<string, int> currentSong = songTimesSecond[i];
    // cout<<currentSong.second<<endl;
    if(currentSong.second < sevenMinuteInseconds) {
      // cout<<currentSong.first<< " "<<currentSong.second<<endl;
      for(int j=i+1; j<songTimesSecond.size(); j++) {
        // cout<<currentSong.second + songTimesSecond[j].second<<endl;
        if(currentSong.second + songTimesSecond[j].second == sevenMinuteInseconds) {
          cout<<currentSong.first + songTimesSecond[j].first<<endl;
          return {currentSong.first, songTimesSecond[j].first};
        }
      }
    }
  }
  return {};
}

int main() {
  
    const vector<pair<string, string>> songTimes1 = {
      {"Stairway to Heaven", "8:05"}, {"Immigrant Song", "2:27"},
      {"Rock and Roll", "3:41"}, {"Communication Breakdown", "2:29"},
      {"Good Times Bad Times", "2:48"}, {"Hot Dog", "3:19"},
      {"The Crunge", "3:18"}, {"Achilles Last Stand", "10:26"},
      {"Black Dog", "4:55"}
    };
    // vector<string> res = findSongs(songTimes1);
    // for(int i=0; i<res.size(); i++) {
    //   cout<<res[i]<<"\t";
    // }
    cout<<endl;
    const vector<pair<string, string>> songTimes2 = {
      {"Stairway to Heaven", "8:05"}, {"Immigrant Song", "2:27"},
      {"Rock and Roll", "3:41"}, {"Communication Breakdown", "2:29"},
      {"Good Times Bad Times", "2:48"}, {"Black Dog", "4:55"},
      {"The Crunge", "3:18"}, {"Achilles Last Stand", "10:26"},
      {"The Ocean", "4:31"}, {"Hot Dog", "3:19"}
    };
    const vector<pair<string, string>> songTimes3 = {
      {"Stairway to Heaven", "8:05"}, {"Immigrant Song", "2:27"},
      {"Rock and Roll", "3:41"}, {"Communication Breakdown", "2:29"},
      {"Hey Hey What Can I Do", "4:00"}, {"Poor Tom", "3:00"},
      {"Black Dog", "4:55"}
    };
    const vector<pair<string, string>> songTimes4 = {
      {"Hey Hey What Can I Do", "4:00"}, {"Rock and Roll", "3:41"},
      {"Communication Breakdown", "2:29"}, {"Going to California", "3:30"},
      {"On The Run", "3:50"}, {"The Wrestler", "3:50"},
      {"Black Mountain Side", "2:11"}, {"Brown Eagle", "2:20"}
    };  
    const vector<pair<string, string>> songTimes5 = {
      {"Celebration Day", "3:30"}, {"Going to California", "3:30"}
    };
    const vector<pair<string, string>> songTimes6 = {
      {"Rock and Roll", "3:41"}, {"If I lived here", "3:59"},
      {"Day and night", "5:03"}, {"Tempo song", "1:57"}
    };

vector<string> res1 = findSongs(songTimes1);
// vector<string> res2 = findSongs(songTimes2);
// vector<string> res3 = findSongs(songTimes3);
// vector<string> res4 = findSongs(songTimes4);
// vector<string> res5 = findSongs(songTimes5);
// vector<string> res6 = findSongs(songTimes6);
  return 0;
}
