PPL Assignment
IRM2015006
q4.cpp
Go to the documentation of this file.
1 /* perform breakup of k unhappiest couples, and assign the
2  girls who became single, another (new) boyfriend
3  */
4 
5 #include "../boys/allboys.h"
6 #include "../girls/allgirls.h"
7 #include "../gifts/gift.h"
8 #include "../couples/couple.h"
9 #include "../utils/read_data.h"
10 #include "../utils/couple_utils.h"
11 #include "../utils/logger/logger.h"
12 
13 #include "../configs.h"
14 
15 int main(int argc, char **argv)
16 {
17  int k = K;
18  if (argc >= 2)
19  k = atoi(argv[1]);
20  Logger logger(LOG_FILE);
21 
22  std::vector<Boy*> boys = readAllBoys(BOY_FILE);
23  std::vector<Girl*> girls = readAllGirls(GIRL_FILE);
24  std::vector<Gift> gifts = readAllGifts(GIFT_FILE);
25 
26  logger.info("Processing for question 4", true);
27  logger.log("boys", std::to_string(boys.size()) + " record read", true);
28  logger.log("girls", std::to_string(girls.size()) + " record read", true);
29  logger.log("gifts", std::to_string(gifts.size()) + " record read", true);
30 
31  std::vector<Couple> couples = makeCouples(boys, girls, &logger);
32 
33  logger.log("couples", std::to_string(couples.size()) + " formed", true);
34 
35  logger.info("Couples list", true);
36  for (int i = 0; i < (int)couples.size(); i++)
37  logger.log("couple"+std::to_string(i+1),
38  couples[i].boy->name+" and "+couples[i].girl->name, true);
39 
40  performGifting(&couples, &gifts, &logger);
41 
42  if (k > (int)couples.size()) {
43  logger.log("Error", "K is more than couples", true);
44  return 1;
45  }
46 
47  std::vector<Couple> hc = getKUnhappiestCouples(couples, k);
48  logger.info(std::to_string(k)+ " unhappiest Couples list", true);
49  for (int i = 0; i < (int)hc.size(); i++)
50  logger.log("couple"+std::to_string(i+1),
51  hc[i].boy->name+" and "+hc[i].girl->name, true);
52 
53  logger.info("Performing breakup of k unhappiest couples and assign the girls new boyfriends", true);
54  performBreakupAndPairAgain(hc, &couples, &boys, &girls, &logger);
55  return 0;
56 }
#define K
Definition: configs.h:14
std::vector< Gift > readAllGifts(std::string filename)
Definition: read_data.h:86
void info(const std::string msg, bool print=false)
Definition: logger.cpp:18
int main(int argc, char **argv)
Definition: q4.cpp:15
void log(const std::string type, const std::string msg, bool print=false)
Definition: logger.cpp:27
Definition: logger.h:8
#define BOY_FILE
Definition: configs.h:2
std::vector< Girl * > readAllGirls(std::string filename)
Definition: read_data.h:50
std::vector< Boy * > readAllBoys(std::string filename)
Definition: read_data.h:14
#define LOG_FILE
Definition: configs.h:11
std::vector< Couple > getKUnhappiestCouples(std::vector< Couple > couples, int k)
Definition: couple_utils.h:167
std::vector< Couple > makeCouples(int k, std::vector< Boy * >, std::vector< Girl * >, Logger *logger)
Definition: q10.cpp:51
#define GIFT_FILE
Definition: configs.h:8
void performGifting(int k, std::vector< Couple > *couples, std::vector< Gift > *giftlist, Logger *logger)
Definition: q10.cpp:94
void performBreakupAndPairAgain(std::vector< Couple >happyCouples, std::vector< Couple > *couples, std::vector< Boy * > *boys, std::vector< Girl * > *girls, Logger *logger)
Definition: couple_utils.h:193
#define GIRL_FILE
Definition: configs.h:5