当前位置: 首页 > wzjs >正文

建设机械网站平台seo资讯

建设机械网站平台,seo资讯,个人网站怎么做淘宝客,广州做网站建设的公司百度之星2024 初赛第一场 补给 题干描述问题分析:C代码Java代码:Python代码补充说明: 题干描述 参考自马蹄集OJ,原文链接1 可怕的战争发生了,小度作为后勤保障工作人员,也要为了保卫国家而努力。 现在有 …

百度之星2024 初赛第一场 补给

    • 题干描述
    • 问题分析:
    • C++代码
    • Java代码:
    • Python代码
    • 补充说明:

题干描述

参考自马蹄集OJ,原文链接1

可怕的战争发生了,小度作为后勤保障工作人员,也要为了保卫国家而努力。
现在有 𝑁(1≤𝑁≤103)个堡垒需要补给,然而总的预算 𝐵(1≤𝐵≤10^9)是有限的。
现在已知第 𝑖 个堡垒需要价值 𝑃(𝑖)的补给,并且需要 𝑆(𝑖)的运费。- 鉴于小度与供应商之间长期稳定的合作关系,供应商慷慨地提供了一次特别的采购优惠。 - 具体而言,小度可以选择对某次补给进行半价采购。- 这意味着,如果小度决定在向第 𝑖 个堡垒提供补给时利用这一优惠,- 那么此次补给的采购及运输总费用将减少至 ⌊𝑃(𝑖)/2⌋+𝑆(𝑖),其中优惠价格按照向下取整的原则计算。- 对于其他堡垒 j,补给的采购和运输费用则保持不变,即 𝑃(𝑗)+𝑆(𝑗)。请计算小度的最多能给多少堡垒提供补给?

格式
输入格式:

第1行2个整数:𝑁和 𝐵 。(1≤𝑁≤103,1≤𝐵≤10^9); 第2到 𝑁+1行:第 𝑖+1
行包含两个空格分隔的整数,𝑃(𝑖)和𝑆(𝑖)。(0≤P(i),S(i)≤10^9)。

输出格式:

1 行 1 个整数表示能提供补给的最大数。

样例 1
输入:

5 29
6 3
2 8
10 2
1 2
12 5

输出:

4

**

问题分析:

1.注意本题要求的是尽可能多的堡垒,那么我们的目标就是尽量优先那些花费少的堡垒
2.读题的时候要注意,每个堡垒花费来自两个方面,一个是补给本身𝑃(𝑗),一个是运费𝑆(𝑗)),所以考虑的时候,应该是二者的和𝑃(𝑗)+𝑆(𝑗)。
3.为了尽可能多的补给堡垒,那么应该对运费和补给费用的和(𝑃(𝑗)+𝑆(𝑗))从小到大进行排序。
4.考虑优惠政策,由于只能用一次,为了优惠的最多,是不是考虑给贵的堡垒?但是如果直接给最贵的可能导致钱变少了,因此是不是应该先从少的开始,直到不够了,再试试能不能通过打折为更多的堡垒供给。
5.因此本地就是排序+贪心(贪心策略:每次选择总费用最少的堡垒)。

C++代码

参考文章2

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>using namespace std;typedef long long ll;const int N=1010;struct node
{ll p;ll s;ll sum;
}a[N];bool cmp(node x,node y)
{return x.sum<y.sum;
}int ans;int main()
{int n,B; cin>>n>>B;for(int i=1;i<=n;i++) cin>>a[i].p>>a[i].s;for(int i=1;i<=n;i++) a[i].sum=a[i].p+a[i].s;sort(a+1,a+1+n,cmp);for(int i=1;i<=n;i++){if(B>=a[i].sum){B-=a[i].sum;ans++;}else{if(B>=floor(a[i].p/2)+a[i].s){ans++;break;}}}cout<<ans<<endl;return 0;
}

Java代码:

import java.util.Scanner;
import java.util.*;class Main {static class Fort {long p;long s;long sum;Fort(long p, long s) {this.p = p;this.s = s;this.sum = p + s;}}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int N = scanner.nextInt();long B = scanner.nextLong();Fort[] forts = new Fort[N];for (int i = 0; i < N; i++) {long p = scanner.nextLong();long s = scanner.nextLong();forts[i] = new Fort(p, s);}Arrays.sort(forts, Comparator.comparingLong(f -> f.sum));int maxCount = 0;for (int i = 0; i < N; i++) {long discountedCost = forts[i].p / 2 + forts[i].s;if (discountedCost > B) {continue;}long remaining = B - discountedCost;int count = 1;for (int j = 0; j < N; j++) {if (j == i) {continue;}if (remaining >= forts[j].sum) {remaining -= forts[j].sum;count++;} else {break;}}if (count > maxCount) {maxCount = count;}}System.out.println(maxCount);}
}

Python代码

def max_forts():import sysinput = sys.stdin.read().split()idx = 0N = int(input[idx])idx += 1B = int(input[idx])idx += 1forts = []for _ in range(N):p = int(input[idx])idx += 1s = int(input[idx])idx += 1forts.append((p, s, p + s))forts.sort(key=lambda x: x[2])max_count = 0for i in range(N):discounted_cost = forts[i][0] // 2 + forts[i][1]if discounted_cost > B:continueremaining = B - discounted_costcount = 1for j in range(N):if j == i:continueif remaining >= forts[j][2]:remaining -= forts[j][2]count += 1else:breakif count > max_count:max_count = countprint(max_count)max_forts()

补充说明:

大家首先一定要学会基础的内容哦,例如需要自行编写代码,获得用例的输入,本题的C++代码为例:

int n,B; cin>>n>>B;
for(int i=1;i<=n;i++) cin>>a[i].p>>a[i].s;
for(int i=1;i<=n;i++) a[i].sum=a[i].p+a[i].s;
http://www.dtcms.com/wzjs/100502.html

相关文章:

  • 网站做著作权网络营销推广目标
  • 网站设计证书温州网站建设制作
  • 单页网站做cpa北京seo方法
  • 做网站流量是什么游戏优化是什么意思?
  • 新闻类的手机网站怎么做百度联盟广告
  • 政府门户网站群建设项目安卓优化大师老版本
  • 网站空间一般有多大如何设计一个网站页面
  • 优模网windows优化大师有哪些功能
  • 网站 建设 方案全球搜索引擎市场份额
  • wordpress footer谷歌seo详细教学
  • 互联网公司如何赚钱seo类目链接优化
  • 杭州做档口批发的网站seo排名优化是什么意思
  • 长春真正免费的建站系统优化大师班级
  • 手机移动端网站怎么做seo拉新推广怎么做代理
  • 响应式网站建设哪家公司好如何免费搭建自己的网站
  • 做网站一定要有服务器吗个人博客网页设计
  • 东莞连衣裙 东莞网站建设制作网站代码
  • 深圳政府网站字体要求超级优化大师下载
  • 青岛网站建设案例西安seo网站优化
  • 网站地图制作怎么做怎么宣传自己新开的店铺
  • 有没有在线做动图的网站营销推广公司案例
  • 网站做生鲜线下推广建议合肥百度快照优化排名
  • 做网站app要多少钱网站优化推广怎么做
  • 做的网站怎么转成网址链接媒体吧软文平台
  • 网站怎么做定位功能广东网站seo策划
  • 网站模板信息不存在企业官网首页设计
  • 邯郸网站建设报价网站策划报告
  • wordpress搜索全站网站模板定制
  • 建设项目管理公司网站百度指数明星人气榜
  • 江西赣鄂皖路桥投资有限公司网站建设十八大禁用黄app入口