티스토리 뷰

출처 : 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;

}



댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/02   »
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
글 보관함