学校打算为全体学生拍一张年度纪念照。根据要求,学生需要按照 非递减 的高度顺序排成一行。
排序后的高度情况用整数数组 expected 表示,其中 expected[i] 是预计排在这一行中第 i 位的学生的高度(下标从 0 开始)。
给你一个整数数组 heights ,表示 当前学生站位 的高度情况。heights[i] 是这一行中第 i 位学生的高度(下标从 0 开始)。
返回满足 heights[i] != expected[i] 的 下标数量 。
思路:排序后进行比较,计数即可。(懒得手撕排序了,直接上sort函数)
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
class Solution {
public:
int heightChecker(vector<int>& heights) {
vector<int> sorted = heights;
sort(sorted.begin(), sorted.end());
int count = 0;
for (int i = 0; i < heights.size(); i++){
if (heights[i] != sorted[i])
count++;
}
return count;
}
};
int main(){
Solution s;
vector<int> heights = {1,1,4,2,1,3};
cout << s.heightChecker(heights) << endl;
return 0;
}