codeforces---1042B- Vitamins(JAVA)

2023-10-20 10:40
文章标签 java codeforces vitamins 1042b

本文主要是介绍codeforces---1042B- Vitamins(JAVA),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Vitamins

Description

Berland shop sells n kinds of juices. Each juice has its price ci. Each juice includes some set of vitamins in it. There are three types of vitamins: vitamin “A”, vitamin “B” and vitamin “C”. Each juice can contain one, two or all three types of vitamins in it.
Petya knows that he needs all three types of vitamins to stay healthy. What is the minimum total price of juices that Petya has to buy to obtain all three vitamins? Petya obtains some vitamin if he buys at least one juice containing it and drinks it.

Input

The first line contains a single integer n(1≤n≤1000)— the number of juices.
Each of the next n lines contains an integer ci (1≤ci≤100000)and a string si
— the price of the i-th juice and the vitamins it contains. String si contains from
1 to 3 characters, and the only possible characters are “A”, “B” and “C”. It is guaranteed that each letter appears no more than once in each string si. The order of letters in strings si is arbitrary.

Output

Print -1 if there is no way to obtain all three vitamins. Otherwise print the minimum total price of juices that Petya has to buy to obtain all three vitamins.

Sample

Input
4
5 C
6 B
16 BAC
4 A
Output
15

Input
2
10 AB
15 BA
Output
-1

Input
5
10 A
9 BC
11 CA
4 A
5 B
Output
13

Input
6
100 A
355 BCA
150 BC
160 AC
180 B
190 CA
Output
250

Input
2
5 BA
11 CB
Output
16

Note

In the first example Petya buys the first, the second and the fourth juice. He spends 5+6+4=15 and obtains all three vitamins. He can also buy just the third juice and obtain three vitamins, but its cost is 16, which isn’t optimal.
In the second example Petya can’t obtain all three vitamins, as no juice contains vitamin “C”.

题目解释

大体意思就是卖很多种饮料。每种饮料可能包含维生素A,B,C一种或多种。我们要做的就是,从输入的数据中,找出能完全获取三种维生素ABC的最低价格。
注意啦:字母ABC的顺序是可以打乱的,但是每条数据每种维生素只会出现一次
我写的程序一如既往没有任何算法哈哈哈哈哈,真是尴尬。。。。就是硬写。什么DP、回溯、递归什么的在我脑子里都只有一个名字哈哈哈哈哈。所以。。。开始吧

Java 代码实现

package algorithm_study;
import java.util.Arrays;
import java.util.Scanner;
public class Vitamins {public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();int mina=Integer.MAX_VALUE, minb=Integer.MAX_VALUE, minc =Integer.MAX_VALUE, minab=Integer.MAX_VALUE, minac=Integer.MAX_VALUE, minbc=Integer.MAX_VALUE, min3=Integer.MAX_VALUE;int wa=0, wb=0,wc=0,wab=0,wac=0,wbc=0,w3=0;while(n>=0){String str = "";str = sc.nextLine();String[] temp = str.split(" ");if(temp.length ==2){if(temp[1].length()==3){ //当vitamins包含3种时w3 = Integer.parseInt(temp[0]);if(w3<min3){min3 = w3;}}if(temp[1].length()==2 && (temp[1].equals("AB")|| temp[1].equals("BA"))){wab = Integer.parseInt(temp[0]);if(wab<minab){minab = wab;}}if(temp[1].length()==2 && (temp[1].equals("AC")|| temp[1].equals("CA"))){wac = Integer.parseInt(temp[0]);if(wac<minac){minac = wac;}}if(temp[1].length()==2 && (temp[1].equals("BC")|| temp[1].equals("CB"))){wbc = Integer.parseInt(temp[0]);if(wbc<minbc){minbc = wbc;}}if(temp[1].length()==1 && temp[1].equals("A")){wa = Integer.parseInt(temp[0]);if(wa<mina){mina = wa;}}if(temp[1].length()==1 && temp[1].equals("B")){wb = Integer.parseInt(temp[0]);if(wb<minb){minb = wb;}}if(temp[1].length()==1 && temp[1].equals("C")){wc = Integer.parseInt(temp[0]);if(wc<minc){minc = wc;}}}n--;}int[] juice = {min3,addExact(mina,minbc),addExact(minb,minac),addExact(minc,minab),addExact(mina,addExact(minb,minc)),addExact(minab,minac),addExact(minab,minbc),addExact(minac,minbc),addExact(minac,minab)};if(min3!=Integer.MAX_VALUE || (mina !=Integer.MAX_VALUE && minbc!=Integer.MAX_VALUE) || (minb !=Integer.MAX_VALUE && minac !=Integer.MAX_VALUE)|| (mina!=Integer.MAX_VALUE && minb!=Integer.MAX_VALUE && minc!=Integer.MAX_VALUE)|| (minab!=Integer.MAX_VALUE && minac!=Integer.MAX_VALUE) || (minab!=Integer.MAX_VALUE && minbc!=Integer.MAX_VALUE) || (minac!=Integer.MAX_VALUE && minbc!=Integer.MAX_VALUE) || (minac!=Integer.MAX_VALUE && minab!=Integer.MAX_VALUE)){		Arrays.sort(juice);System.out.println(juice[0]);}else{System.out.println(-1);}}public static int addExact(int x, int y) { //判断溢出int r = x + y;if (((x ^ r) & (y ^ r)) < 0) {r=Integer.MAX_VALUE;}return r;}
}

叨叨

codeforces是真的好噢,能根据wrong test number来排查你的程序可能错在哪里。真是棒。
在这里插入图片描述

这篇关于codeforces---1042B- Vitamins(JAVA)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/246564

相关文章

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja