学校打算为全体学生拍一张年度纪念照。根据要求,学生需要按照 非递减 的高度顺序排成一行。
排序后的高度情况用整数数组 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;
}