题目链接

题意:

输入:

第一个: n k p x y

第二行:k个数

n: 数的数量

k:n个数中已经知道的k个数

p:n个数取值的上界,下界是1

x:n个数的和的上界x

y:n个数的中位数至少是 y

输出:

补充其余的n-k个数,使得这个n个数的和不大于x,中位数不小于y

解题思想:

对已经知道的k个数,判断其中大于等于y的数median有几个,

若median<=n/2 说明已知道的k个数中大于y的不到一半,则在未知道的n-k个数中,补充y,当median>n/2 时候停止

若还没有补充完n-k个数,则补充1,

根据上面得到的是满足中位数大于等于y的最小序列

下面判断这个n个数的和是否大于x

这样就ok了

Java程序:

import java.util.Scanner;

public class B540 {
static void run0(){
Scanner sc= new Scanner(System.in);
int n = sc.nextInt();// n 个数
int k = sc.nextInt();// 已经知道的 k个数
int p = sc.nextInt();// n 个数可取的最大值p,最小值是 1
int x = sc.nextInt(); // n 个数的和的上界
int y = sc.nextInt(); // n 个数的中位数至少为 y
int[] a = new int[n]; // 存放n 个数
int median = 0;// = n/2 时候是中位数
int i=0;
int sum = 0; // n个数的和
for(i=0;i<k;i++){
a[i] = sc.nextInt();
if(a[i]>= y) // 大于y 的个数
median++;
}
// 若median <=n/2 说明输入的数中> y 的数还不够
while(i<n && median<= n/2){
a[i++] = y;
median++;
}
// 其他值至少是 1
for(;i<n;i++){
a[i] = 1;
}
// 上面的值是满足中位数至少是y的 一个条件
// 下面考虑n个数的和要小于 x
for(int j=0;j<n;j++)
sum += a[j];
if(sum>x || median<= n/2){
System.out.println(-1);
return;
} for(int j=k;j<n;j++)
System.out.print(a[j]+" ");
}
public static void main(String[] args){
run0(); }
}

Python程序:

n,k,p,x,y = map(int,raw_input().split())

a = map(int,raw_input().split())
median = 0
s = 0
for i in a:
s+=i
if i>=y:
median +=1
b = []
while median<= n/2:
b.append(y)
median = median +1
while len(b)+k < n :
b.append(1)
if len(b)+k>n or sum(b)+s >x:
print -1
else:
for i in b:
print i,

540B :School Marks的更多相关文章

  1. CF#301 B:School Marks(贪心)

    B:School Marks 有n个测试,已经完成了k个,每个测试得分为a[i],接下来的分数不知道,让我们求出任何一个满足题意的即可,满足题意就是n个测试的得分总和<=x, 中位数>=y ...

  2. 第142天:Size Marks下载安装和使用方法

    Size Marks下载安装使用方法 一.下载安装 1.下载Size marks:链接: https://pan.baidu.com/s/1breyMf1 密码: fjsn 2. 复制 Size Ma ...

  3. CentOS 7上的程序管理:rpm、yum和源码编译安装

    简介 在Linux的早期时代(也许吧?我猜的.也可能是Unix.),想要在系统上安装一款应用程序,是比较复杂的.需要专业的人员自行获取程序的源代码,并且编译安装,这是非常的复杂且需要一定的专业功底的, ...

  4. Go语言学习:01-基本语法

    目录 基本语法 源文件构成 数据类型 基本类型变量 数组 切片 创建切片 调整容量 字符串与切片 常量 String Map 控制 条件语句 if switch 循环语句 函数 函数定义 函数变量 闭 ...

  5. Linux程序包管理之rpm

    rpm简介 rpm( Red Hat Package Manager )是一个开放的软件包管理系统.它工作于Red Hat Linux及其他Linux系统,成为Linux中公认的软件包管理标准. rp ...

  6. Linux程序包管理.md

    rpm 简介 RPM包管理员(简称RPM,全称为The RPM Package Manager)是在Linux下广泛使用的软件包管理器.RPM此名词可能是指.rpm的文件格式的软件包,也可能是指其本身 ...

  7. 从零开始学 Java - 利用 Nginx 负载均衡实现 Web 服务器更新不影响访问

    还记得那些美妙的夜晚吗 你洗洗打算看一个小电影就睡了,这个时候突然想起来今天晚上是服务器更新的日子,你要在凌晨时分去把最新的代码更新到服务器,以保证明天大家一觉醒来打开网站,发现昨天的 Bug 都不见 ...

  8. Vim光标定位

    *定位到指定行n: 输入"nG". 或输入"ngg". 或输入":n" 这里,n就是指定的行的行号.注意,有时候G=gg. *跳到屏幕顶部: ...

  9. Swift函数编程之Map、Filter、Reduce

    在Swift语言中使用Map.Filter.Reduce对Array.Dictionary等集合类型(collection type)进行操作可能对一部分人来说还不是那么的习惯.对于没有接触过函数式编 ...

随机推荐

  1. iOS中MVC设计模式

    在组织大型项目的代码文件时,我们常用MVC的思想.MVC的概念讲起来非常简单,就和对象(object)一样.但是理解和应用起来却非常困难.今天我们就简单总结一下MVC设计理念. MVC(Model V ...

  2. 000 VS2013 c++ 框架

    #include <Windows.h> //全局函数声明 LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wParam, ...

  3. 华硕电脑安装ubuntu出现问题及决方案

    问 题 一:华硕电脑安装ubuntu时无线网络禁用解决方案:打开终端(Ctrl+alt+t)运行命令sudo rmmod acer-wmi,然后开启无线,连接上后便可以上网(附上ubuntu论坛上讨论 ...

  4. 63.Assignment to name ignored, since the identifier is never used

    在文件中单独定义一些信号变量,如start_flag,即使进行(*KEEP=“TRUE”*)的声明,但在cdc文件上依然找不到start_flag变量,这是为什么呢?因为ISE综合器非常聪明,对一些没 ...

  5. dd面试经历

     HR面:看了我的简历,说fe做的简历就是不一样哈哈好吧,然后随便问了点项目,又问了什么时候可以去实习,就没了.三面:基本数据结构.冒泡排序.数组去重.ie与主流浏览器事件绑定.垂直居中的css实现方 ...

  6. JS获取字符串长度(英文占1个字符,中文汉字占2个字符)

    方法一: String.prototype.gblen = function() { var len = 0; for (var i = 0; i < this.length; i++) { i ...

  7. C#加密解密算法汇总(转)

    方法一:     //须添加对System.Web的引用     using System.Web.Security;           ...           /// <summary& ...

  8. 设置 Eclipse 智能代码提示,大幅度减少 alt+/ 使用频率,打每个字都出现代码提示的办法

    以前网上有个英文版本的,现在自己汉化一下...O(∩_∩)O 哈哈 ~   http://www.cnblogs.com/lidabo/archive/2013/03/05/2944245.html ...

  9. 阿里云无线&前端团队是如何基于webpack实现前端工程化的

    背景 前端经历了初期的野蛮生长(切图,写简单的特效)——为了兼容浏览器兼容性而出现的各种类库(JQUERY,YUI等——mv*(饱暖思淫欲,代码多了,也就想到怎样组织代码结构,backbone,ang ...

  10. 增强学习贪心算法与Softmax算法

    (一) 这个算法是基于一个概率来对探索和利用进行折中:每次尝试时,以概率进行探索,即以均匀概率随机选取一个摇臂,以的概率进行利用,即以这个概率选择当前平均奖赏最高的摇臂(如有多个,则随机选取). 其中 ...