Monday, June 30, 2014

TopCoder High School SRM 30 Level one - 250 pt - How Many Birthdays solution

TopCoder High School SRM 30 Level one - 250 pt - How Many Birthdays:

Problem Statement

     You have several friends and you want to know which of them are celebrating their birthdays today. You are given a String[] friends, each element of which is formatted as "NAME DAY MONTH" (quotes for clarity), where NAME is a friend's name, and DAY and MONTH are integers representing the day and month, respectively, of that friend's birthday. Today's date is given in the String today, formatted as "DAY MONTH" (quotes for clarity). Return a String[] containing the names of all your friends who have birthdays today, sorted in alphabetical order. If none of your friends have a birthday today, return an empty String[].

Definition

    
Class: HowManyBirthdays
Method: getList
Parameters: vector <string>, string
Returns: vector <string>
Method signature: vector <string> getList(vector <string> friends, string today)
(be sure your method is public)

Limits

    
Time limit (s): 2.000
Memory limit (MB): 64

Notes

- In this problem, all months have exactly 31 days.

Constraints

- friends will contain between 1 and 50 elements, inclusive.
- Each element of friends will be formatted as "NAME DAY MONTH" (quotes for clarity).
- today will be formatted as "DAY MONTH" (quotes for clarity).
- In each element of friends, NAME will contain between 1 and 20 lowercase letters ('a'-'z'), inclusive.
- Each DAY in friends and today will be an integer between 1 and 31, inclusive, with no leading zeroes.
- Each MONTH in friends and today will be an integer between 1 and 12, inclusive, with no leading zeroes.
- No two elements of friends will contain the same NAMEs.

Examples

0)
    
{"igor 13 6"}
"14 6"
Returns: { }
You have only one friend and he celebrated his birthday yesterday. So, your method should return an empty String[].
1)
    
{"sasha 12 5"}
"12 5"
Returns: {"sasha" }
sasha celebrates his birthday today, so your method should return {"sasha"}.
2)
    
{"larisa 27 3", "kira 7 4", "max 12 3", "kirill 27 3"}
"27 3"
Returns: {"kirill", "larisa" }
3)
    
{"zoro 31 2", "pokemon 16 12", "spiderman 31 12", "dragon 13 7", "elf 31 12"}
"31 12"
Returns: {"elf", "spiderman" }
4)
    
{"ann 6 6", "tanya 6 6", "gudi 6 6", "ruslik 6 6", "alla 6 6", "serge 10 10"}
"6 6"
Returns: {"alla", "ann", "gudi", "ruslik", "tanya" }
5)
    
{"ahdjakdd 31 12", "fhdfjha 1 1", "wefhjks 13 6", "fkajahsdaaajj 6 7"}
"5 12"
Returns: { }

This problem statement is the exclusive and proprietary property of TopCoder, Inc. Any unauthorized use or reproduction of this information without the prior written consent of TopCoder, Inc. is strictly prohibited. (c)2003, TopCoder, Inc. All rights reserved.  

TopCoder High School SRM 30 Level one - 250 pt - How Many Birthdays editorial: http://community.topcoder.com/tc?module=Static&d1=hs&d2=match_editorials&d3=hs_srm30

TopCoder High School SRM 30 Level one - 250 pt - How Many Birthdays solution: 


#include <iostream>
#include <sstream>
#include <vector>
#include <algorithm>
using namespace std;

class HowManyBirthdays {
    public: vector <string> getList(vector <string> f, string t) {
        vector <string> a;      
        for(int i=0; i<f.size(); i++) {
            stringstream b(f[i]);
            string c, d, e;
            b>>c>>d>>e;
            if(d+' '+e==t) a.push_back(c);
        }
        sort(a.begin(), a.end());
        return a;
    }
};


tomekkulczynski's solution to HowManyBirthdays : http://community.topcoder.com/tc?module=HSProblemSolution&cr=14886245&rd=10654&pm=7429


#include <string>
#include <vector>
#include <cmath>
#include <algorithm>
#include <set>
#include <map>
#include <cstdlib>
#include <cstdio>
#include <sstream>
#include <iostream>
using namespace std;

class HowManyBirthdays 
{
  public:
  vector <string> getList(vector <string> s, string t) 
  {
    vector<string> ret;
    int i,j;
    for(i=0;i<s.size();i++)
    {
      for(j=0;s[i][j]!=' ';j++);
      if(s[i].substr(j+1)==t) ret.push_back(s[i].substr(0,j));
    }
    sort(ret.begin(),ret.end());
    return ret;
  }
};

No comments:

Post a Comment