zoukankan      html  css  js  c++  java
  • [Nowcoder] 六一儿童节(拼多多)

    六一儿童节,老师带了很多好吃的巧克力到幼儿园。每块巧克力j的重量为w[j],对于每个小朋友i,当他分到的巧克力大小达到h[i] (即w[j]>=h[i]),他才会上去表演节目。老师的目标是将巧克力分发给孩子们,使得最多的小孩上台表演。可以保证每个w[i]> 0且不能将多块巧克力分给一个孩子或将一块分给多个孩子。 

    输入描述:
    第一行:n,表示h数组元素个数
    第二行:n个h数组元素
    第三行:m,表示w数组元素个数
    第四行:m个w数组元素
    输出描述:
    上台表演学生人数
    输入例子1:
    3 
    2 2 3
    2
    3 1
    输出例子1:
    1

    六一儿童节,老师手里有x块巧克力,总共有y名小朋友,当小朋友手中得到的巧克力大于等于给定值时,他才可以上台表演。求一共有几个小朋友可以上台表演

    将给定的巧克力重量数组以及小朋友上次所需要的巧克力数组排序(升序)。

    然后用一个数count来统计能上台表演的小朋友个数,用一个idx表示用掉的巧克力数。

    如果最小重量的巧克力满足当前小朋友的需要,那么count+1,idx+1表示用掉了巧克力。如果不满足当前小朋友的需要,那么开始计算第二块巧克力是否满足。

    #include <iostream>
    #include <string>
    #include <algorithm>
    #include <vector>
    using namespace std;
    
    int main()
    {
        int n;
        while (cin >> n)
        {
            vector<int> h(n);
            for (int i = 0; i < n; ++i)
                cin >> h[i];
            int m;
            cin >> m;
            vector<int> w(m);
            for (int i = 0; i < m; ++i)
                cin >> w[i];
            sort(h.begin(), h.end());
            sort(w.begin(), w.end());
            int count = 0;
            int idx = 0;
            for (int i = 0; i < n; ++i)
            {
                for (int j = idx; j < m; ++j)
                {
                    if (h[i] <= w[j])
                    {
                        count++;
                        idx = j + 1;
                        break;
                    }
                }
            }
            cout << count << endl;
        }
        return 0;
    }
  • 相关阅读:
    索引唯一性扫描(INDEX UNIQUE SCAN)
    索引范围扫描(INDEX RANGE SCAN)
    算法设计与分析——回溯法算法模板
    操作系统考试复习大纲
    windows cmd 生成文件目录树
    Java 匿名类和lambda表达式
    下载Abook 高等教育出版社网站资料
    操作系统——银行家算法(Banker's Algorithm)
    算法设计与分析——最大团问题(回溯法)
    JVM内存区域
  • 原文地址:https://www.cnblogs.com/immjc/p/9420481.html
Copyright © 2011-2022 走看看