问题 N: 小球(点击)

时间限制: 1 Sec  内存限制: 128 MB

                                                                          提交: 462  解决: 172

                                                              [提交] [状态] [讨论版] [命题人:admin]

题目描述

有R个红色盒子和B个蓝色盒子,还有R个红色小球和B个蓝色小球。每个盒子只能装一个小球,每个小球都要放在一个盒子里。如果把一个红色小球放在一个红色盒子里,那么得分是C。如果把一个蓝色小球放在一个蓝色盒子里,那么得分是D。如果把一个红色小球放在一个蓝色盒子里,那么得分是E。如果把一个蓝色小球放在一个红色盒子里,那么得分也是E。现在给出R,B,C,D,E。应该如何放置这些小球进盒子,才能使得总得分最大?输出最大的总得分。

输入

一行,5个整数,分别是R,B,C,D,E。(1 ≤ R ≤ 100,1 ≤ B ≤ 100,  -1000 ≤ C,D,E ≤ 1000)

输出

一个整数,最大总得分。

样例输入

复制样例数据

2  3  100  400  200

样例输出

1400

提示

#include<stdio.h>
int main()
{
long long int sum[100006],n,m,c,d,e,k,i,j,temp;
scanf("%lld%lld%lld%lld%lld",&n,&m,&c,&d,&e);
k=0;
if(n>=m){ //先判断n和m的个数关系 因为如果不相同肯定不是交换m+n次
for(i=0;i<=m;i++){
sum[k++]=2*i*e+(n-i)*c+(m-i)*d; //i表示从n和m中各自拿出的个数 由此可以计算总分数
}
}
else{
for(i=0;i<=n;i++){
sum[k++]=2*i*e+(n-i)*c+(m-i)*d;
}
}
for(i=0;i<k-1;i++){
for(j=0;j<k-i-1;j++){ //由于没改头文件 所以就先没用sort排序
if(sum[j]<sum[j+1]){
temp=sum[j];
sum[j]=sum[j+1];
sum[j+1]=temp;
}
}
}
printf("%lld\n",sum[0]); //输出最大的积分
return 0;
}

虽然题目简单 但由于没搞清楚字母i的含义导致多次错误。

    scanf("%lld%lld%lld%lld%lld",&n,&m,&c,&d,&e);
k=0;
if(n>=m){
for(i=0;i<=m;i+=2){
sum[k++]=i*e+(n-(i/2))*c+(m-(i/2))*d; //其实i并不是只可以取0 2 4 等偶数 因为由于i
表示的含义是从m和n中各取小球的数目 所以i可
以取任意小于n或m的值。(错误点)
}
}
else{
for(i=0;i<=n;i+=2){
sum[k++]=i*e+(n-(i/2))*c+(m-(i/2))*d;
}
}

总结 sort 和 cmp函数

1.对整形数值的使用:

int   cmp(int x,int y)

{

return x>y;    // 从大到小     return x<y;  // 从 小到大

}

这里面和在冒泡排序中对x和y的判断相反    因为这是返回时候的大小关系

而冒泡是对返回之前的大小关系的判断 然后做出排序

* 同样适用于 lang lang int 但注意一定要将cmp函数中所有的int换掉 不然提交后会报错(报错今天遇到最多的就是忘记加& 确实     不应该)。

2.对浮点型的数值的使用:

double cmp(double x,double y)

{

return x>y;    // 从大到小     return x<y;  // 从 小到大

}

3.达到像冒泡中对二维数组a[i][0]的排序 :(使用结构体)

普通冒泡排序:

     for(i=0;i<k-1;i++){
for(j=0;j<k-i-1;j++){
if(sum[j][0]<sum[j+1][0]){
temp=sum[j][0];
sum[j][0]=sum[j+1][0];
sum[j+1][0]=temp; temp=sum[j][1];
sum[j][1]=sum[j+1][1];
sum[j+1][1]=temp;
}
}
}

使用结构体排序: (c++头文件)

struct node{
int x,y; //定义结构体
}a[10006]; int cmp(node a,node b)
{
return a.x<b.x; //按照x 即a[0][0]和a[1][0]的大小关系排序 若为y则按照a[0][1]和a[1][1]
} for(i=0;i<n;i++){
scanf("%d%d",&a[i].x,&a[i].y); //结构体的输入
} //使用sort sort(a,a+n,cmp); //从0开始的n个值的排序 sort(a,a+n+1,cmp); //从1开始的n个值的排序

小球(总结sort和cmp函数、结构体排序)的更多相关文章

  1. <algorithm>里的sort函数对结构体排序

    题目描述 每天第一个到机房的人要把门打开,最后一个离开的人要把门关好.现有一堆杂乱的机房签到.签离记录,请根据记录找出当天开门和关门的人. 输入描述: 每天的记录在第一行给出记录的条目数M (M &g ...

  2. 网上关于sort结构体排序都不完整,我来写一个完整版的 2014-08-09 16:50 60人阅读 评论(0) 收藏

    主要参考sort函数_百度文库, 但是那篇有错误 2.结构体排序,a升,b降,c降 平板视图 打印? 01 #include <iostream> 02 #include <algo ...

  3. qsort 与sort 对结构体排序实例

    qsort 与sort 对结构体排序实例 #include<bits/stdc++.h> using namespace std; typedef struct { string book ...

  4. 转载 从最简单的vector中sort用法到自定义比较函数comp后对结构体排序的sort算法

    转载自:http://www.cnblogs.com/cj695/p/3863142.html sort函数在使用中非常好用,也非常简单,而且效率与冒泡或者选择排序不是一个数量级.本文就sort函数在 ...

  5. 【转】 从最简单的vector中sort用法到自定义比较函数comp后对结构体排序的sort算法

    sort函数在使用中非常好用,也非常简单,而且效率与冒泡或者选择排序不是一个数量级.本文就sort函数在vector中的用法分为sort函数入门用法与自定义comp比较函数比较结构体这两个最基本的功能 ...

  6. 从最简单的vector中sort用法到自定义比较函数comp后对结构体排序的sort算法

    sort函数在使用中非常好用,也非常简单,而且效率与冒泡或者选择排序不是一个数量级.本文就sort函数在vector中的用法分为sort函数入门用法与自定义comp比较函数比较结构体这两个最基本的功能 ...

  7. 【C++】从最简单的vector中sort用法到自定义比较函数comp后对结构体排序的sort算法

    sort函数在使用中非常好用,也非常简单,而且效率与冒泡或者选择排序不是一个数量级.本文就sort函数在vector中的用法分为sort函数入门用法与自定义comp比较函数比较结构体这两个最基本的功能 ...

  8. sort的cmp函数

    sort的cmp函数只能写return a>b;或者return a<b;

  9. go语言的排序、结构体排序

    原文:https://studygolang.com/articles/1598 晚上准备动手写点 go 的程序的时候,想起 go 如何排序的问题.排序 sort 是个基本的操作,当然搜索 searc ...

随机推荐

  1. CF808E Selling Souvenirs

    题目链接: http://codeforces.com/contest/808/problem/E 题目大意: Petya 有 n 个纪念品,他能带的最大的重量为 m,各个纪念品的重量为 wi,花费为 ...

  2. Vue基础:子组件抽取与父子组件通信

    在工作中承担一部分前端工作,主要使用Vue + Element UI. 随着版本迭代,需求增加,页面往往变得更加臃肿,不易维护.学习子组件的封装和抽取,能更好适应需求. 为什么需要子组件 可复用 将重 ...

  3. 公众号使用微信sdk的正确姿势

    当我们做微信登录授权,微信公众号的分享,微信的h5支付等等等等的时候难免会用到微信sdk,当我们用react或vue做的spa应用,直接引入后会发现,在按安卓上可以正常调试,而ios上一直报签名错误( ...

  4. Java——动态创建Class(不写入文件,直接从内存中创建class)

    原文:https://blog.csdn.net/zhao_xinhu/article/details/82499062#commentsedit 参考:https://www.cnblogs.com ...

  5. 进程间的通信——pipe通信

    当进程创建管道文件后,其建立的子进程自动继承该文件. 管道通信分为命名管道和未命名管道,他们的区别是命名管道在当创建他的进程结束后,系统仍存有该文件 管道的命令格式为 pipe(fds) 其中 fds ...

  6. Istio VirtualService 虚拟服务

    概念及示例 VirtualService 描述了一个或多个用户可寻址目标到网格内实际工作负载之间的映射 . 虚拟服务让您配置如何在服务网格内将请求路由到服务,这基于 Istio 和平台提供的基本的连通 ...

  7. C#命名空间大全

    Microsoft.Jscript Jscript语言进行编译和代码生成的Jscript运行库和类. Microsoft.VisualBasic Visual Basic .NET运行库.此运行库与V ...

  8. 11.Java连接Redis_Jedis_测试联通

    使用Java开发项目的时候使用Redis的话,目前有一些开源API可以使用. 最常用的就是jedis,它提供了许多基于Java的对象和方法来调用Redis的指令. jedis的jar包下载地址http ...

  9. 【Mathtype】安装Mathtype后,word无法粘贴的问题

    Win10安装mathtype后,word工具栏中自动添加mathtype的选项(mathtype为了使用户更加方便使用,故自动添加),但是却导致word无法粘贴.如何解决该问题? [方案1]官网描述 ...

  10. 深度学习入门: CNN与LSTM(RNN)

    1. 理解深度学习与CNN: 台湾李宏毅教授的入门视频<一天搞懂深度学习>:https://www.bilibili.com/video/av16543434/ 其中对CNN算法的矩阵卷积 ...