#include "pixelGameEngine.h" #include "olcPGEX_QuickGUI.h" #include using namespace olc; QuickGUI::TextBox*prevTextBox=nullptr; QuickGUI::TextBox*activeBox=nullptr; // Override base class with your custom functionality class ChampionsLeaguePointSolver : public olc::PixelGameEngine { std::string slurp(std::ifstream& in) { std::ostringstream sstr; sstr << in.rdbuf(); return sstr.str(); } struct ScoreData{ int difficulty=0; std::string song; int totalEX=0; int ex1=0,ex2=0,ex3=0; std::string str()const{ return "["+std::to_string(difficulty)+"] "+song+": "+std::to_string(totalEX)+" total, "+" EX1: "+std::to_string(ex1)+" EX2: "+std::to_string(ex2)+" EX3: "+std::to_string(ex3); } friend std::ostream&operator<<(std::ostream&os,const ScoreData&data){ os<>p1; //Index to song followed by EX of song. std::vector>p2; std::vector>p3; std::setp1Picked; std::setp2Picked; std::setp3Picked; int totalEX=0; int remainingA,remainingB,remainingC; }; std::vectordataA,dataB; std::vector>player1Score,player2Score,player3Score; std::vectorcases; std::vector bestComboA,bestComboB; int calculationStep=0; void Evaluate(int caseInd,bool ASet){ auto ChooseSong = [&](SongCombinations&combinations,std::vector&dat,int index){ if(combinations.remainingA>0&&combinations.p1Picked.count(index)==0&&combinations.p2Picked.count(index)==0&&combinations.p3Picked.count(index)==0){ combinations.remainingA--; if(ASet){ combinations.totalEX+=player1Score[index].first; combinations.p1.push_back(std::pair{index,player1Score[index].first}); }else{ combinations.totalEX+=player1Score[index].second; combinations.p1.push_back(std::pair{index,player1Score[index].second}); } combinations.p1Picked.insert(index); }else if(combinations.remainingB>0&&combinations.p1Picked.count(index)==0&&combinations.p2Picked.count(index)==0&&combinations.p3Picked.count(index)==0){ combinations.remainingB--; if(ASet){ combinations.totalEX+=player2Score[index].first; combinations.p1.push_back(std::pair{index,player2Score[index].first}); }else{ combinations.totalEX+=player2Score[index].second; combinations.p1.push_back(std::pair{index,player2Score[index].second}); } combinations.p2Picked.insert(index); }else if(combinations.remainingC>0&&combinations.p1Picked.count(index)==0&&combinations.p2Picked.count(index)==0&&combinations.p3Picked.count(index)==0){ combinations.remainingC--; if(ASet){ combinations.totalEX+=player3Score[index].first; combinations.p1.push_back(std::pair{index,player3Score[index].first}); }else{ combinations.totalEX+=player3Score[index].second; combinations.p1.push_back(std::pair{index,player3Score[index].second}); } combinations.p3Picked.insert(index); } }; if(ASet){ bestComboA.push_back({}); bestComboA[caseInd].remainingA=cases[caseInd].p1Amt; bestComboA[caseInd].remainingB=cases[caseInd].p2Amt; bestComboA[caseInd].remainingC=cases[caseInd].p3Amt; SongCombinations testCombo=bestComboA[caseInd]; for(int i=0;i<12;i++){ SongCombinations c1=testCombo; ChooseSong(c1,dataA,i); for(int j=0;j<12;j++){ SongCombinations c2=c1; ChooseSong(c2,dataA,j); for(int k=0;k<12;k++){ SongCombinations c3=c2; ChooseSong(c3,dataA,k); for(int l=0;l<12;l++){ SongCombinations c4=c3; ChooseSong(c4,dataA,l); for(int m=0;m<12;m++){ SongCombinations c5=c4; ChooseSong(c5,dataA,m); for(int n=0;n<12;n++){ SongCombinations c6=c5; ChooseSong(c6,dataA,n); if(bestComboA[caseInd].totalEX&p1:bestComboA[caseInd].p1){ std::cout<<"P1["<&p2:bestComboA[caseInd].p2){ std::cout<<"P2["<&p3:bestComboA[caseInd].p3){ std::cout<<"P3["<&p1:bestComboB[caseInd].p1){ std::cout<<"P1["<&p2:bestComboB[caseInd].p2){ std::cout<<"P2["<&p3:bestComboB[caseInd].p3){ std::cout<<"P3["<tabNext=p1Score; } p1Score->tabNext=p2Score; p1Score->tabPrev=prevTextBox; p2Score->tabNext=p3Score; p2Score->tabPrev=p1Score; prevTextBox=p3Score; p3Score->tabPrev=p2Score; } QuickGUI::Label*label; QuickGUI::TextBox*p1Score; QuickGUI::TextBox*p2Score; QuickGUI::TextBox*p3Score; }; QuickGUI::Manager gui; std::vectorsongs; QuickGUI::Label*p1Label; QuickGUI::Label*p2Label; QuickGUI::Label*p3Label; QuickGUI::Button*calculateButton; std::arrayinputButtons; int totalCalculationSteps=0; bool calculating=false; ChampionsLeaguePointSolver() { // Name your application sAppName = "Champions League Point Solver"; } public: bool OnUserCreate() override { std::ifstream file("assets/team2"); std::string line; //First two lines are garbage data. std::getline(file,line); std::getline(file,line); for(int i=0;i<12;i++){ std::getline(file,line); int marker=0; ScoreData dat{ stoi(GetNext(marker,line)), GetNext(marker,line), stoi(GetNext(marker,line)), stoi(GetNext(marker,line)), stoi(GetNext(marker,line)), stoi(GetNext(marker,line))}; player1Score.push_back(std::pair{0,0}); player2Score.push_back(std::pair{0,0}); player3Score.push_back(std::pair{0,0}); dataA.push_back(dat); songs.push_back(SongElement{gui,dat.song.substr(0,dat.song.find(',')),{4.f,2.f+12*i+16}}); } //Two more lines of garbage data. std::getline(file,line); std::getline(file,line); for(int i=0;i<12;i++){ std::getline(file,line); int marker=0; ScoreData dat{ stoi(GetNext(marker,line)), GetNext(marker,line), stoi(GetNext(marker,line)), stoi(GetNext(marker,line)), stoi(GetNext(marker,line)), stoi(GetNext(marker,line))}; player1Score[i].second=0; player2Score[i].second=0; player3Score[i].second=0; dataB.push_back(dat); songs.push_back(SongElement{gui,dat.song.substr(0,dat.song.find(',')),{4.f,2.f+12*(i+13)+16}}); } std::cout<<"File Contents:"<bVisible=false; inputButtons[i]->Enable(false); } for(int i=0;i<5;i++){ for(int j=0;j<5;j++){ for(int k=0;k<5;k++){ if(i+j+k==6){ cases.push_back(TestCase{i,j,k}); } } } } return true; } bool OnUserUpdate(float fElapsedTime) override { Clear(VERY_DARK_CYAN); if(calculateButton->bPressed&&!calculating){ calculateButton->Enable(false); int index=0; for(SongElement&element:songs){ element.p1Score->Enable(false); element.p2Score->Enable(false); element.p3Score->Enable(false); element.p1Score->bHasBackground=element.label->bHasBackground=false; if(index<12){ player1Score[index].first=element.p1Score->sText.length()>0?stoi(element.p1Score->sText):0; player2Score[index].first=element.p2Score->sText.length()>0?stoi(element.p2Score->sText):0; player3Score[index].first=element.p3Score->sText.length()>0?stoi(element.p3Score->sText):0; }else{ player1Score[index-12].second=element.p1Score->sText.length()>0?stoi(element.p1Score->sText):0; player2Score[index-12].second=element.p2Score->sText.length()>0?stoi(element.p2Score->sText):0; player3Score[index-12].second=element.p3Score->sText.length()>0?stoi(element.p3Score->sText):0; } element.p2Score->bHasBackground=element.label->bHasBackground=false; element.p3Score->bHasBackground=element.label->bHasBackground=false; index++; } calculating=true; calculationStep=0; totalCalculationSteps=cases.size()*2; bestComboA={}; bestComboB={}; } QuickGUI::TextBox*prevActiveBox=activeBox; gui.Update(this); gui.Draw(this); if(highestEX!=0){ DrawString({112,4},std::to_string(highestEX)+" EX",YELLOW); } if(!calculating){ if(prevActiveBox!=nullptr){ for(int i=0;ibVisible=true; inputButtons[i]->Enable(true); if(inputButtons[i]->bPressed){ if(i==10){ prevActiveBox->sText=prevActiveBox->sText.substr(0,std::max(0,int(prevActiveBox->sText.length())-1)); }else{ if(prevActiveBox->sText.length()<4){ prevActiveBox->sText+=inputButtons[i]->sText; } } activeBox=prevActiveBox; prevActiveBox->m_bTextEdit=true; TextEntryEnable(true,prevActiveBox->sText); } } } } if(calculating){ activeBox=nullptr; if(calculationStephighestEX&&A.p1Picked.size()+B.p1Picked.size()==4&&A.p2Picked.size()+B.p2Picked.size()==4&&A.p3Picked.size()+B.p3Picked.size()==4){ highestEX=A.totalEX+B.totalEX; picked1=A; picked2=B; std::cout<<"New Best Song Combinations found for Final Picks - Total EX: "<&p1:picked1.p1){ std::cout<<"P1["<&p2:picked1.p2){ std::cout<<"P2["<&p3:picked1.p3){ std::cout<<"P3["<&p1:picked2.p1){ std::cout<<"P1["<&p2:picked2.p2){ std::cout<<"P2["<&p3:picked2.p3){ std::cout<<"P3["<bPressed=false; calculateButton->Enable(true); int index=0; for(SongElement&element:songs){ element.p1Score->Enable(true); element.p2Score->Enable(true); element.p3Score->Enable(true); if(index<12){ if(picked1.p1Picked.count(index)){element.p1Score->bHasBackground=element.label->bHasBackground=true;} if(picked1.p2Picked.count(index)){element.p2Score->bHasBackground=element.label->bHasBackground=true;} if(picked1.p3Picked.count(index)){element.p3Score->bHasBackground=element.label->bHasBackground=true;} }else{ if(picked2.p1Picked.count(index-12)){element.p1Score->bHasBackground=element.label->bHasBackground=true;} if(picked2.p2Picked.count(index-12)){element.p2Score->bHasBackground=element.label->bHasBackground=true;} if(picked2.p3Picked.count(index-12)){element.p3Score->bHasBackground=element.label->bHasBackground=true;} } index++; } } } return true; } }; int main() { ChampionsLeaguePointSolver solver; if (solver.Construct(320, 320, 4, 4)) solver.Start(); return 0; }