알고리즘/기타

[HackerRank] A Very Big Sum

히더 2018. 9. 27. 14:34

출처 : https://www.hackerrank.com/challenges/a-very-big-sum/problem


#include <bits/stdc++.h>


using namespace std;


vector<string> split_string(string);


long aVeryBigSum(vector<long> ar) {

    long ans=0;

    for(int i=0; i<ar.size(); i++) ans+=ar[i];

    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<long> ar(ar_count);


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

        long ar_item = stol(ar_temp[i]);


        ar[i] = ar_item;

    }


    long result = aVeryBigSum(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;

}