2860. 让所有学生保持开心的分组方法数

简介: 【9/3】

给你一个下标从 0 开始、长度为 n 的整数数组 nums ,其中 n 是班级中学生的总数。班主任希望能够在让所有学生保持开心的情况下选出一组学生:

如果能够满足下述两个条件之一,则认为第 i 位学生将会保持开心:

这位学生被选中,并且被选中的学生人数 严格大于 nums[i] 。
这位学生没有被选中,并且被选中的学生人数 严格小于 nums[i] 。
返回能够满足让所有学生保持开心的分组方法的数目。

示例 1:

输入:nums = [1,1]
输出:2
解释:
有两种可行的方法:
班主任没有选中学生。
班主任选中所有学生形成一组。
如果班主任仅选中一个学生来完成分组,那么两个学生都无法保持开心。因此,仅存在两种可行的方法。
示例 2:

输入:nums = [6,0,3,3,6,7,2,7]
输出:3
解释:
存在三种可行的方法:
班主任选中下标为 1 的学生形成一组。
班主任选中下标为 1、2、3、6 的学生形成一组。
班主任选中所有学生形成一组。

提示:

1 <= nums.length <= 105
0 <= nums[i] < nums.length

题解:
只需要排序之后,在每个分界点判断,前后是否符合条件。
判断这个i>nums[i-1]&&nums[i]>i。

class Solution {
public:
    int countWays(vector<int>& nums) {
        int n = nums.size();
        sort(nums.begin(),nums.end());
        int ans=0;
        for (int i=0;i<n;i++){
            if(i==n-1){
                if(nums[i]<=i){
                    ans++;                   
                }                
            }
            else if(i==0){
                if(nums[i]>0){
                    ans++;
                }
            }
            else if(i>nums[i-1]&&nums[i]>i){
                ans++;
                cout<<i<<" "<<nums[i-1]<<" "<<nums[i]<<endl;
            }
        }
        return ans;
    }
};
目录
相关文章
|
7月前
leetcode-6133:分组的最大数量
leetcode-6133:分组的最大数量
57 0
LeetCode题解-让所有学生保持开心的分组方法数
LeetCode题解-让所有学生保持开心的分组方法数
|
6月前
1064 朋友数 (20 分) //感觉题目有问题。
1064 朋友数 (20 分) //感觉题目有问题。
|
机器学习/深度学习 Cloud Native
【刷题日记】2044. 统计按位或能得到最大值的子集数目
本次刷题日记的第 8 篇,力扣题为:2044. 统计按位或能得到最大值的子集数目 ,中等
LeetCode每日一题——1684. 统计一致字符串的数目
给你一个由不同字符组成的字符串 allowed 和一个字符串数组 words 。如果一个字符串的每一个字符都在 allowed 中,就称这个字符串是 一致字符串 。
85 0
|
iOS开发
LeetCode每日一题——1773. 统计匹配检索规则的物品数量
给你一个数组 items ,其中 items[i] = [typei, colori, namei] ,描述第 i 件物品的类型、颜色以及名称。
90 0
【刷题记录】40. 组合总和 II
【刷题记录】40. 组合总和 II
113 0
【刷题记录】40. 组合总和 II
【刷题记录】39. 组合总和
【刷题记录】39. 组合总和
126 0
【刷题记录】39. 组合总和
漫画:去掉一个数,如何让剩余的数乘积最大?
举个例子,给定如下数组:要删除哪个元素,才能使得剩余元素的乘积最大呢?
113 0
漫画:去掉一个数,如何让剩余的数乘积最大?