试题 算法提高 双十一抢购

资源限制

时间限制:1.0s 内存限制:256.0MB

问题描述

  一年一度的双十一又来了,某网购网站又开始了半价销售的活动。

  小G打算在今年的双十一里尽情地购物,以享受购买的极度快感,她已经列好了她想买的物品的列表。

  当然小G并不是出身富贵家庭,所以她网银里的钱只是一个有限的整数S(单位:元)。

  这次抢购她打算遵循这三个原则选择每一个物品:

  1.先买能“赚”最多的;

  2.在“赚”一样多的情况下,先买最便宜的(这样买的东西就可能更多了);

  3.在前两条里都判断不了购买顺序的话,先购买在列表里靠前的。

  (由于网站里还是有一部分商品并没有打五折,所以2的情况(“赚”的钱数为0)是完全可能发生的)

  现在,在双十一的这一天,你要帮小G编写一个程序,来看看她应该去买她列表里的哪些物品。(总价格不要超过S哦)

  要是帮她写好这个程序的话,或许你能在光棍节这一天里赢得她的芳心哦~

输入格式

  输入共N+1行。

  第一行包含两个整数S和N,S表示小G的可用金额,N表示她看上的物品个数。

  接下来N行,对应每一个物品,每行有两个整数a和b,a是物品的原价(单位:元),b为0或1,若b为0,则此物品不半价,若b为1,则此物品半价销售。

输出格式

  输出共一行,为小G要买的物品序号(从1开始),用空格隔开,注意按序号从小到大输出。

  若小G一件都买不了,则输出0.

样例输入

10 3

5 0

4 0

10 1

样例输出

2 3

样例输入

10 3

11 0

21 1

100 1

样例输出

0

数据规模和约定

  0<S<=10000,0<N<=1000,每一个a和b满足0<a<=1000且b=0或1。

  1. package com.company;
  2. import java.util.Arrays;
  3. import java.util.Scanner;
  4. public class 双十一抢购 {
  5. public static void main(String[] args) {
  6. Scanner sc=new Scanner(System.in);
  7. //sum表示小G的可用金额
  8. double sum=sc.nextDouble();
  9. //N表示她看上的物品个数
  10. int N=sc.nextInt();
  11. //创建所有商品的集合
  12. Goods []arr=new Goods[N];
  13. //给商品赋值
  14. for(int i=0;i<N;i++){
  15. arr[i]=new Goods();
  16. arr[i].price=sc.nextDouble();
  17. arr[i].off=sc.nextInt();
  18. arr[i].num=i+1;
  19. }
  20. //按照下面这种方式排序
  21. for(int i=0;i<N-1;i++){
  22. for(int j=i+1;j<N;j++){
  23. if(arr[i].price*arr[i].off<arr[j].price*arr[j].off){//先买能“赚”最多的
  24. Goods temp;
  25. temp=arr[j];
  26. arr[j]=arr[i];
  27. arr[i]=temp;
  28. }
  29. else if(arr[i].price*arr[i].off==arr[j].price*arr[j].off){
  30. if(arr[i].price>arr[j].price){//在“赚”一样多的情况下,先买最便宜的
  31. Goods temp;
  32. temp=arr[j];
  33. arr[j]=arr[i];
  34. arr[i]=temp;
  35. }
  36. else if(arr[i].price==arr[j].price){
  37. if(arr[i].num>arr[j].num){
  38. //在前两条里都判断不了购买顺序的话,先购买在列表里靠前的
  39. Goods temp;
  40. temp=arr[j];
  41. arr[j]=arr[i];
  42. arr[i]=temp;
  43. }
  44. }
  45. }
  46. }
  47. }
  48. //创建一个结果的数组,进行存储要购买的序号
  49. int []result=new int[N];
  50. //用来存储商品的数目
  51. int count=0;
  52. //按照刚才排号的顺序,进行购买
  53. for(int i=0;i<N;i++){
  54. double realPrice=arr[i].price-arr[i].price*arr[i].off*0.5;
  55. if(realPrice<=sum){
  56. sum-=realPrice;
  57. result[count]=arr[i].num;
  58. count++;
  59. }
  60. }
  61. //如果没有商品的话,就输出0,结束程序
  62. if(count==0){
  63. System.out.print(0);
  64. System.exit(0);
  65. }
  66. //给商品号进行排序
  67. Arrays.sort(result);
  68. for(int i=0;i<N;i++){
  69. if(result[i]!=0){
  70. System.out.print(result[i]+" ");
  71. }
  72. }
  73. }
  74. //创建一个商品的类
  75. public static class Goods{
  76. int num;//序号
  77. double price;//原价
  78. int off;//折扣
  79. public Goods(){
  80. num=0;
  81. price=0;
  82. off=0;
  83. }
  84. }
  85. }

Java实现 蓝桥杯 算法提高 双十一抢购的更多相关文章

  1. Java实现 蓝桥杯 算法提高 进攻策略加强(暴力)

    试题 算法提高 进攻策略加强 问题描述 植物大战僵尸这款游戏中,还有一个特别的玩儿法:玩家操纵僵尸进攻植物. 首先,僵尸有m种(每种僵尸都是无限多的),玩家可以选择合适的僵尸来进攻.使用第i种僵尸需要 ...

  2. Java实现 蓝桥杯 算法提高 小X的购物计划

    试题 算法提高 小X的购物计划 问题描述 小X打算去超市shopping.小X没什么钱,只有N元.超市里有M种物品,每种物品都需要money,在小X心中有一个重要度.有的物品有无限件,有的物品只有几件 ...

  3. Java实现 蓝桥杯 算法提高 天天向上(DP)

    试题 算法提高 天天向上 问题描述 A同学的学习成绩十分不稳定,于是老师对他说:"只要你连续4天成绩有进步,那我就奖励给你一朵小红花."可是这对于A同学太困难了.于是,老师对他放宽 ...

  4. Java实现 蓝桥杯 算法提高 欧拉函数(数学)

    试题 算法提高 欧拉函数 问题描述 老师出了一道难题,小酱不会做,请你编个程序帮帮他,奖金一瓶酱油: 从1-n中有多少个数与n互质? |||||╭══╮ ┌═════┐ ╭╯让路║═║酱油专用车║ ╰ ...

  5. Java实现 蓝桥杯 算法提高 计算超阶乘(暴力)

    试题 算法提高 计算超阶乘 问题描述 计算1*(1+k)(1+2k)(1+3k)-(1+n*k-k)的末尾有多少个0,最后一位非0位是多少. 输入格式 输入的第一行包含两个整数n, k. 输出格式 输 ...

  6. Java实现蓝桥杯 算法提高 线段和点

    算法提高 线段和点 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 有n个点和m个区间,点和区间的端点全部是整数,对于点a和区间[b,c],若a>=b且a<=c,称点a满 ...

  7. Java实现蓝桥杯-算法提高 P1003

    算法提高 P1003 时间限制:1.0s 内存限制:256.0MB 作为一名网络警察,你的任务是监视电子邮件,看其中是否有一些敏感的关键词.不过,有些狡猾的犯罪嫌疑人会改变某些单词的字母顺序,以逃避检 ...

  8. Java实现蓝桥杯 算法提高 八皇后 改

    **算法提高 8皇后·改** 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 规则同8皇后问题,但是棋盘上每格都有一个数字,要求八皇后所在格子数字之和最大. 输入格式 一个8*8的棋 ...

  9. Java实现 蓝桥杯 算法提高 高精度减法(JDK方法)

    试题 算法提高 高精度减法 问题描述 高精度减法 输入格式 两行,表示两个非负整数a.b,且有a > b. 输出格式 一行,表示a与b的差 样例输入 1234567890987654321 99 ...

随机推荐

  1. 设计模式之GOF23状态模式

    状态模式state 场景:当具有许多状态并且需要频繁改变时,用这种模式 -电梯的运行:维修,正常,自动关门,自动开门,向上运行,向下运行,消防状态 -红绿灯:红灯,黄灯,绿灯 -企业或政府系统:公文的 ...

  2. Web_php_include

    0x01 函数分析 <?php show_source(__FILE__); echo $_GET['hello']; $page=$_GET['page']; while (strstr($p ...

  3. WriteUp_easy_sql_堆叠注入_强网杯2019

    题目描述 随便注 解题过程 查看源码,发现应该不适合sqlmap自动化注入,该题应该是让你手工注入: <!-- sqlmap是没有灵魂的 --> <form method=" ...

  4. Docker容器映射到宿主机只有tcp6没有tcp问题

    问题描述: Docker容器映射到宿主机后,查询端口连接只有tcp6没有tcp,通过ipv4地址连接时无法连接成功. 处理方法: 1.检查是否开启ipv4端口转发 sysctl net.ipv4.ip ...

  5. AT命令集详解

    1.2 AT的优点. 命令简单易懂,并且采用标准串口来收发AT命令,这样对设备控制大大简化了,转换成简单串口编程了. AT命令提供了一组标准的硬件接口--串口.这个简化的硬件设计.较新的电信网络模块, ...

  6. day05:数组与字典常识(20170217)

    #1:数组功能的使用:print ("a4A".isdecimal()) #print ("18".isdigit()) #判断是否是数字print (&quo ...

  7. 客服端负载均衡:Spring Cloud Ribbon

    Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具.服务间的调用,API网关的请求转发都是通过Ribbon实现的. 在微服务架构中使用客户端负载均衡需要两步: (1) ...

  8. Java-main方法中调用非static方法

    java的calss中,在public static void main(String[] args) { }方法中调用非static的方法:在main方法中创建该calss的对象,用对象调用非sta ...

  9. 学会使用Hdlbits网页版Verilog代码仿真验证平台

    给大家推荐一款网页版的 Verilog代码编辑仿真验证平台,这个平台是国外的一家开源FPGA学习网站,通过“https://hdlbits.01xz.net/wiki/Main_Page” 地址链接进 ...

  10. ELK-日志管理平台

    elk日志收集工具 1.日志在工作当中的重要性             1 分析日志的意义: 2 1.分析日志监控系统运行的状态 3 2.分析日志来定位程序的bug 4 3.分析日志监控网站访问流量 ...