티스토리 뷰

출처 : https://www.hackerrank.com/challenges/birthday-cake-candles/problem


#include <bits/stdc++.h>


using namespace std;


vector<string> split_string(string);


int birthdayCakeCandles(vector<int> ar) {

    int ans=1; 

    sort(ar.begin(),ar.end());

    int tmp = ar[ar.size()-1];

    if(ar.size()>2) {

        for(int i=ar.size()-2;i>=0;i--) {

        if(tmp==ar[i]) ans++;

        else break;

        }

    }

    else if(ar.size()==2) {

        if(tmp==ar[0]) ans++;

    }

    

    return ans;

}


int main()

{

    ofstream fout(getenv("OUTPUT_PATH"));


    int ar_count;

    cin >> ar_count;

    cin.ignore(numeric_limits<streamsize>::max(), '\n');


    string ar_temp_temp;

    getline(cin, ar_temp_temp);


    vector<string> ar_temp = split_string(ar_temp_temp);


    vector<int> ar(ar_count);


    for (int i = 0; i < ar_count; i++) {

        int ar_item = stoi(ar_temp[i]);


        ar[i] = ar_item;

    }


    int result = birthdayCakeCandles(ar);


    fout << result << "\n";


    fout.close();


    return 0;

}


vector<string> split_string(string input_string) {

    string::iterator new_end = unique(input_string.begin(), input_string.end(), [] (const char &x, const char &y) {

        return x == y and x == ' ';

    });


    input_string.erase(new_end, input_string.end());


    while (input_string[input_string.length() - 1] == ' ') {

        input_string.pop_back();

    }


    vector<string> splits;

    char delimiter = ' ';


    size_t i = 0;

    size_t pos = input_string.find(delimiter);


    while (pos != string::npos) {

        splits.push_back(input_string.substr(i, pos - i));


        i = pos + 1;

        pos = input_string.find(delimiter, i);

    }


    splits.push_back(input_string.substr(i, min(pos, input_string.length()) - i + 1));


    return splits;

}



'알고리즘 > 기타' 카테고리의 다른 글

[HackerRank] Climbing the Leaderboard  (0) 2018.09.28
[HackerRank] Time Conversion  (0) 2018.09.27
[HackerRank] Mini-Max Sum  (0) 2018.09.27
[HackerRank] Staircase  (0) 2018.09.27
[HackerRank] Plus Minus  (0) 2018.09.27
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
글 보관함