Ho 8 elenchi ordinati che ho bisogno di unire in 1 elenco ordinato. Non conosco il modo migliore per farlo. Stavo pensando a quanto segue:Unione di 8 elenchi ordinati in C++, quale algoritmo dovrei usare
void merge_lists_inplace(list<int>& l1, const list<int>& l2)
{
list<int>::iterator end_it = l1.end();
--end_it;
copy(l2.begin(), l2.end(), back_inserter(l1));
++end_it;
inplace_merge(l1.begin(), end_it, l1.end());
}
list<int> merge_8_lists(list<int>[8] lists)
{
merge_lists_inplace(lists[0], lists[1]);
merge_lists_inplace(lists[2], lists[3]);
merge_lists_inplace(lists[4], lists[5]);
merge_lists_inplace(lists[6], lists[7]);
merge_lists_inplace(lists[0], lists[2]);
merge_lists_inplace(lists[4], lists[6]);
merge_lists_inplace(lists[0], lists[4]);
return lists[0];
}
Ma sarebbe meglio preoccuparsi solo dell'ordinamento ultimo?
list<int> merge_8_lists(list<int>[8] lists)
{
for (int i = 1; i < 8; ++i)
copy(lists[i].begin(), lists[i].end(), back_inserter(lists[0]));
lists[0].sort();
return lists[0];
}
Nota a margine: non mi interessa che gli elenchi vengano modificati.
Complimenti per analisi di complessità e pseudocodice. =] –
Wow, impari qualcosa di nuovo ogni giorno. – rlbond
Perché std :: set e non std :: priority_queue? – Drakosha