티스토리 뷰

출처 : https://www.hackerrank.com/challenges/lilys-homework/problem


#include <bits/stdc++.h>


using namespace std;


vector<string> split_string(string);


int cnt(vector<int>arr, vector<int>a, map<int, int> m) {

    int ans = 0;

    for (int i = 0; i<arr.size(); i++) {

        if (arr[i] != a[i]) {

            int tmp = m[a[i]];swap(arr[tmp], arr[i]);

            m[arr[tmp]] = tmp; ans++;

        }

    }

    return ans;

}


int lilysHomework(vector<int> arr) {

    vector<int> v(arr); map<int, int> m;

    for (int i = 0; i < arr.size(); i++) m[arr[i]] = i;

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

    int ans = cnt(arr, v, m);

    reverse(v.begin(), v.end());

    return min(ans, cnt(arr, v, m));

}


int main()

{

    ofstream fout(getenv("OUTPUT_PATH"));


    int n;

    cin >> n;

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


    string arr_temp_temp;

    getline(cin, arr_temp_temp);


    vector<string> arr_temp = split_string(arr_temp_temp);


    vector<int> arr(n);


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

        int arr_item = stoi(arr_temp[i]);


        arr[i] = arr_item;

    }


    int result = lilysHomework(arr);


    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/01   »
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
글 보관함