Codeforces Round #697 (Div. 3) E. Advertising Agency

news2025/1/16 13:42:18

翻译:

玛莎在一家广告公司工作。为了推广新品牌,她想和一些博主签约。玛莎总共有𝑛个不同的博主。编号为𝑖的博主拥有𝑎𝑖名粉丝。

由于玛莎的预算有限,她只能与𝑘不同的博主签约。当然,玛莎希望她的广告被尽可能多的人看到。因此,她必须雇佣拥有最大粉丝总数的博主。

帮助她,找到选择𝑘博主的方法,这样他们的粉丝总数是最大的。如果第一种方式至少有一个博主,而第二种方式没有,那么两种方式就被认为是不同的。Masha认为所有的博主都有不同的粉丝(也就是说,没有一个粉丝会关注两个不同的博主)。

例如,如果𝑛=4,𝑘=3,𝑎=[1,3,1,2],那么Masha有两种方法来选择3个粉丝总数最大的博主:

与数字1、2和4的博主签订合同。在这种情况下,关注者数量将等于𝑎1+𝑎2+𝑎4=6。
与第2、3和4号博主签订合同。在这种情况下,关注者数量将等于𝑎2+𝑎3+𝑎4=6。
因为答案可以很大,所以对109+7取模输出。

输入
第一行包含一个整数𝑡(1≤𝑡≤1000)——测试用例的数量。然后是𝑡测试用例。

每个测试用例的第一行包含两个整数𝑛和𝑘(1≤𝑘≤𝑛≤1000)——博主的数量以及您可以与其中的多少人签订合同。

每个测试用例的第二行包含𝑛整数𝑎1,𝑎2,…𝑎𝑛(1≤𝑎𝑖≤𝑛)-每个博主的粉丝数。

可以保证所有测试用例中𝑛的总和不超过1000。

输出
对于每个测试用例,在单独的一行上输出一个整数——选择𝑘博主的方法的数量,这样他们的粉丝总数就可能是最大的。

例子
inputCopy
3.
4个3
1 3 1 2
4个2
1 1 1 1
2 1
1 2
outputCopy
2
6
1
请注意
测试用例在语句中进行了解释。

在第二个测试用例中,以下方法是有效的:

与数字1和2的博主签订合同。在这种情况下,关注者的数量将等于𝑎1+𝑎2=2;
与数字1和3的博主签订合同。在这种情况下,关注者的数量将等于𝑎1+𝑎3=2;
与1号和4号博主签订合同。在这种情况下,关注者的数量将等于𝑎1+𝑎4=2;
与2号和3号博主签订合同。在这种情况下,关注者的数量将等于𝑎2+𝑎3=2;
与2号和4号博主签订合同。在这种情况下,关注者的数量将等于𝑎2+𝑎4=2;
与3号和4号博主签订合同。在这种情况下,关注者数量将等于𝑎3+𝑎4=2。
在第三个测试用例中,以下方式是有效的:

和一个2号博主签了合同。在这种情况下,关注者的数量将等于𝑎2=2。

思路:这道题简单来说,就是求最大值的方案数,刚开始看了一眼还以为是dp,后来一想,就是一道组合数的板子。n个拿k个最大,我们只需要确定第k大的,一共有几个,和需要拿几个即可。就是典型的组合数。代码用了组合数预处理,前边博客写过,O(m)复杂度,可以说是最快的了。

代码:

/*Looking! The blitz loop this planet to search way
 
 Only my RAILGUN can shoot it 今すぐ
 
 身体中を  光の速さで
 
 駆け巡った確かな予感
 
 掴め! 望むものなら残さず
 
 輝ける自分らしさで
 
 信じてるよ  あの日の誓いを
 
 この瞳に光る涙それさえも  強さになるから
 
 */
#include <iostream>
#include <algorithm>
#include <string.h>
#include <string>
#include <math.h>
#include <stdio.h>
#include<vector>
#include<queue>
#include<map>
#include<set>
#include<tuple>
#include<numeric>
#include<stack>
using namespace::std;
typedef long long  ll;
int n,t;
inline __int128 read(){
    __int128 x = 0, f = 1;
    char ch = getchar();
    while(ch < '0' || ch > '9'){
        if(ch == '-')
            f = -1;
        ch = getchar();
    }
    while(ch >= '0' && ch <= '9'){
        x = x * 10 + ch - '0';
        ch = getchar();
    }
    return x * f;
}
inline void print(__int128 x){
    if(x < 0){
        putchar('-');
        x = -x;
    }
    if(x > 9)
        print(x / 10);
    putchar(x % 10 + '0');
}

ll dp[1000005];
int a[1005],m;
const ll N=1e9+7;
ll inv(ll x, ll y) {
    ll re = 1;
    while (y) {
        if (y & 1) {
            re = re * x % N;
        }
        x = x * x % N;
        y /= 2;
    }
    return re % N;
}
ll rt[10005];
ll rte[10005];
ll zud(ll a,ll b){
    if (a==b) {
        return 1;
    }
    if (b>a) {
        return 0;
    }
    return rt[a]*rte[b]%N*rte[a-b]%N;
}
int fsl=1;
void wanyurukong(){
    cin>>n>>m;
//    printf("%d ",fsl);fsl++;
    for (int i =1; i<=n; i++) {
        cin>>a[i];
    }
    ll an=0;
    sort(a+1, a+1+n);
    an=a[n-m+1];
    int ff=1;
    int l=n-m;
    while (a[l]==an&&l>=1) {
        l--;
        ff++;
    }
//    printf("%d ",ff);
    l=n-m+2;
    int dd=1;
    while (a[l]==an&&l<=n) {
        dd++;
        l++;
        ff++;
    }
//    printf("%d %d\n",ff,dd);
    printf("%lld\n",zud(ff, dd));
//    for (int i =1; i<=an; i++) {
//        dp[i]=0;
//    }
//    for (int i  =1; i<=n; i++) {
//        for (int j=an; j>=a[i]; j--) {
//            dp[j]=(dp[j]+dp[j-a[i]])%N;
//        }
//        for (int k=0; k<=an; k++) {
//            printf("%lld ",dp[k]);
//        }printf("\n");
//    }
    
//    printf("%lld\n",dp[an]);
}
int main(){
    ios::sync_with_stdio(false);
    cin.tie(); cout.tie();
    cin>>t;
    dp[0]=1;
    rt[0]=rte[0]=1;
    for (int i =1; i<=10005; i++) {
        rt[i]=rt[i-1]*i%N;
        rte[i]=rte[i-1]*inv(i, N-2)%N;
    }
    while (t--) {
        wanyurukong();
    }
    //wanyurukong
    return 0;
}
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/117341.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LeetCode动态规划—跳跃游戏从跳到头到跳最少下跳到头(45、55)

跳跃游戏跳跃游戏跳跃游戏Ⅱ跳跃游戏 一个下标对应的值为3&#xff0c;那证明这个位置可以跳到前后3个位置的下标处。&#xff08;3均可达&#xff09; 如果依次遍历完这个数组&#xff0c;有下标在跳跃过程中最远位置仍然不可达&#xff0c;即证明无法到达最后一个位置。 可以…

js实现九宫格抽奖功能

分享一下js的九宫格抽奖功能 首先是html部分&#xff1a; <div class"box"><div class"div2">短裙</div><div class"div3">口红</div><div class"div4">草莓</div><div class"div…

【vue】控制台中如何移除数组arr中的值?如何给数组arr中放值?

移除数组arr属性中的值&#xff1a;vm.arr.shift() 新增数组arr属性中的值&#xff1a;vm.arr.push(‘属性值’) 移除atguigu3样式后效果&#xff1a; 向数组arr中添加样式值后效果&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta…

FlinkSql开窗实例:消费kafka写入文本

前言 以前写Flink从kafka入hdfs因为业务需求和老版本缘故都是自定义BucketSink入动态目录中&#xff0c;对于简单的需求可以直接用Flink SQL API进行输出。Flink版本1.13.1。 Flink官网示例 准备 本地下载个kafka&#xff08;单机即可&#xff09;&#xff0c;新建个桌面目…

Unreal 读写自定义配置文件

基础 首先需要自定义一个继承自UObject的类&#xff0c;UCLASS加上config标志 UCLASS(config MyClass) class UMyClass: public UObject将想要和配置文件交互的属性&#xff0c;UFUNCTION加上Config标志 UPROPERTY(Config, EditAnywhere) float TestP;之后只要配置文件内存…

【日常系列】LeetCode《21·综合应用3》

数据规模->时间复杂度 <10^4 &#x1f62e;(n^2) <10^7:o(nlogn) <10^8:o(n) 10^8<:o(logn),o(1) 内容 lc 217 &#xff1a;存在重复元素 https://leetcode.cn/problems/contains-duplicate/ 提示&#xff1a; 1 < nums.length < 10^5 -10^9 < nums[…

Python基础教程(2)——列表、元组、字典、集合、斐波纳契数列、end 关键字、条件控制、循环语句

1.列表 &#xff08;1&#xff09;删除列表的元素 list [Google, Runoob, 1997, 2000] print ("原始列表 : ", list) del list[2] print ("删除第三个元素 : ", list)&#xff08;2&#xff09;Python列表脚本操作符 &#xff08;3&#xff09;嵌套列表…

Arco 属性

文章目录Arco介绍1. 简介1.1 背景1.2 运行环境1.3 浏览器兼容性2. 设计价值观2.1 清晰2.2 一致2.3 韵律2.4 开放3. 设计原则3.1 及时反馈3.2 贴近现实3.3 系统一致性3.4 防止错误发生3.5 遵从习惯3.6 突出重点3.7 错误帮助3.8 人性化帮助4. 界面总体风格4.1 页面风格4.1.1 主色…

知识答题小程序如何制作_分享微信答题抽奖小程序制作步骤

知识答题小程序如何制作&#xff1f;现在越来越多的企业和组织逐步进行各种获奖知识问答小程序。那么&#xff0c;如何制作一个答题小程序呢&#xff1f;今天&#xff0c;我们一起来看看~需要的老板不要走开哦~既然点进来了&#xff0c;那就请各位老板耐心看到最后吧~怎么做一个…

JDBC如何破坏双亲委派机制

JDBC的注册会涉及到java spi机制&#xff0c;即Service Provideer Interface&#xff0c;主要应用于厂商自定义组件或插件中&#xff1b;简单说就是java来定义接口规则和方法&#xff0c;厂商实现具体逻辑&#xff0c;每家厂商根据自己产品实现的逻辑肯定不相同&#xff0c;但上…

数据库查询语句-详细篇

今天来梳理一下数据库的一些查询语句&#xff0c;做软件/移动端/电脑端&#xff0c;开发程序时必然离不开数据库的设计以及查询&#xff1b; 一&#xff1a;具体的代码如下展示&#xff1a; 1.查询数据库指定表的所有信息 select * from uploadimagecode;2.查询当前数据表部…

说说PPT的“只读模式”和“限制编辑”有何区别

对PPT的内容进行保护&#xff0c;使其不能随意编辑&#xff0c;防止意外更改&#xff0c;我们可以将PPT设置成无法编辑、无法改动的“保护模式”。 设置“保护模式”&#xff0c;一般我们都会想到【限制编辑】模式&#xff0c;但在设置的时候&#xff0c;会发现PPT里&#xff…

毕业半年年终总结

毕业半年年终总结 如果说2021年主要的内容是求职和实习 那么2022年一年主要的内容便是毕业和工作 匆匆忙忙 本科毕业了 6月份的时候参加完毕业答辩&#xff0c;也就顺利的毕业了 实际上中途也有过一些插曲&#xff0c;比如毕业设计是制作某某管理系统&#xff0c;基本上所有…

【Java编程进阶】流程控制结构详解

推荐学习专栏&#xff1a;Java 编程进阶之路【从入门到精通】 文章目录1. 流程控制结构2. 顺序结构3. 分支结构3.1 单分支3.2 双分支3.3 多分支 (if-else)3.4 嵌套 if3.5 多分支结构 (switch)4. 循环结构4.1 for 循环4.2 while 循环4.3 do...while循环5. 流程跳转5.1 break5.2 …

【数据结构】优先级队列(堆)

成功就是失败到失败&#xff0c;也丝毫不减当初的热情 目录 1.理解优先级队列 2.优先级队列的底层 2.1 认识堆 2.1.1 堆的概念 2.2.2 堆的存储 2.2 堆的创建 2.2.1 向下调整算法 2.2.2 堆的创建 2.3 堆的插入 2.4 堆的删除 2.5 查看堆顶元素 2.6 堆的运用 3…

windows 11 安装jdk1.8

1.先去JDK官网下载 JDK1.8官网 2.进入到官网之后 3. 点击上图windows选项       按照你的电脑是32位还是64位按需下载(我电脑是64位) 4. 点击下载之后就会跳转到Oracle账号登录界面&#xff08;没有Oracle账号的注册一下这边我就省略了注册了&#xff09; 5.把下载好的…

商业智能BI财务分析,如何从财务指标定位到业务问题

商业智能BI开发人员都会思考如何从财务指标定位到业务问题&#xff0c;就是做了很多的商业智能BI开发&#xff0c;每次也都涉及到了财务分析&#xff0c;各种财务能力指标&#xff0c;各种可视化的分析图表。但是不知道这些财务指标到底能够反映出企业的什么问题&#xff0c;和…

蓝桥杯Python练习题3-十六进制转八进制

资源限制 内存限制&#xff1a;512.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述 给定n个十六进制正整数&#xff0c;输出它们对应的八进制数。 输入格式 输入的第一行为一个正整数n &#xff08;1<n<10&am…

Weston 纹理倒置(render-gl)

纹理倒置 背景 在 render-gl 接入 frame buffer object 实现 off-screen 渲染后,发现得到的渲染图发生了180的倒置. 查阅了有关资料后,在 eglspec.1.5 中的 2.2.2.1 Native Surface Coordinate Systems 找到了答案: The coordinate system for native windows and pixmaps …

2023届毕业生职场第一步:挡飞刀

这篇博客不会教你某一段代码怎么写&#xff0c;某一个知识点怎么入门&#xff0c;但却可以让你在2023年的职场上&#xff0c;躲避飞刀。 目录 1、啥是挡飞刀 2、其他知名大厂也好不到哪里去 3、 毕业生如何躲飞刀&#xff1f; 4、毕业生首选什么样的公司 5、不建议去这样的…