当前位置: 首页 > 编程日记 > 正文

P1194 买礼物

P1194 买礼物

题目描述

又到了一年一度的明明生日了,明明想要买B样东西,巧的是,这B样东西价格都是A元。

但是,商店老板说最近有促销活动,也就是:

如果你买了第I样东西,再买第J样,那么就可以只花K[I,J]元,更巧的是,K[I,J]竟然等于K[J,I]。

现在明明想知道,他最少要花多少钱。

输入输出格式

输入格式:

第一行两个整数,A,B。

接下来B行,每行B个数,第I行第J个为K[I,J]。

我们保证K[I,J]=K[J,I]并且K[I,I]=0。

特别的,如果K[I,J]=0,那么表示这两样东西之间不会导致优惠。

输出格式:

仅一行一个整数,为最小要花的钱数。

输入输出样例

输入样例#1:
【样例输入1】
1 1
0
【样例输入2】
3 3
0 2 4
2 0 2
4 2 0
输出样例#1:
【样例输出1】
1
【样例输出2】
7

说明

样例解释2

先买第2样东西,花费3元,接下来因为优惠,买1,3样都只要2元,共7元。

(同时满足多个“优惠”的时候,聪明的明明当然不会选择用4元买剩下那件,而选择用2元。)

数据规模

对于30%的数据,1<=B<=10。

对于100%的数据,1<=B<=500,0<=A,K[I,J]<=1000。

分析:

这个题目我们要买所有的商品,只需要把所有的点都连起来就可以了。所以显然就是一个最小生成树。而且我们也会发现选商品的过程和最小生成树的选取一个点非常相似。而且,整个价格是确定好的,最优解只有一种(可能多个),所以在最开始从任意一个点出发都是一样的。minn[i]记录买i东西的最低价。

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #define f(ii,l,r) for(int ii=l;ii<=r;ii++)
 5 #define maxn 501
 6 using namespace std;
 7 long long  ans=0,v;
 8 int n,m,x,y;
 9 long long g[maxn][maxn],minn[maxn],q;
10 bool vis[maxn];
11 int main() {
12     cin>>q>>n;
13     f(i,1,n)
14     f(j,1,n){
15         //读入边 
16         cin>>g[i][j];
17         if(g[i][j]==0)
18         g[i][j]=q;
19     }
20     memset(minn,0x3f,sizeof(minn));
21     //第一个点按原价买 
22     //minn[i]记录买i东西的最低价 
23     minn[1]=q;
24     memset(vis,0,sizeof(vis));
25     //
26     f(i,1,n) {
27         int k=0;
28         f(j,1,n)
29         //找最优点 
30         if(!vis[j]&&(minn[j]<minn[k]))
31             k=j;
32         vis[k]=true;
33         //用最优点更新所有边 
34         f(j,1,n)
35         if(!vis[j]&&(minn[j]>g[k][j]))
36             minn[j]=g[k][j];
37     }
38     f(i,1,n)
39     ans+=minn[i];
40     cout<<ans<<endl;
41     return 0;
42 }

转载于:https://www.cnblogs.com/Renyi-Fan/p/7435572.html

相关文章:

.NET 框架中的 WMI 命名空间

.NET 框架中的WMI 命名空间.NET框架中与WMI规范有关的命名空间有两个,分别是System.Management和System.Management.Instrumentation两个命名空间。其中System.Managemen命名空间提供的类对象为访问各种管理对象提供了面向对象的编程接口&#xff0c;而System.Management.Instr…

一个已经存在 10 年,却被严重低估的库!

来源 | 写代码的明哥头图 | 下载于视觉中国今天介绍的是一个已经存在十三年&#xff0c;但是依旧不红的库 decorator&#xff0c;好像很少有人知道他的存在一样。这个库可以帮你做什么呢 &#xff1f;其实很简单&#xff0c;就是可以帮你更方便地写 python 装饰器代码&#xff…

linux_shell 第一章 变量

2019独角兽企业重金招聘Python工程师标准>>> #!/bin/sh //解释器 a"1"; //对a进行赋值&#xff0c;等号两边不能有空格&#xff0c;以冒号("")方式传入&#xff0c;变量不需要先定义即可使用 b"2;" string"…

让vim不要自动添加新的注释行

vim里面有一个特性&#xff0c;如果你在一行注释后新加一行&#xff0c;vim会自动在下一行的开始位置添加注释符号。例如对于C/C来说 //This is a comment line// 第二行的"//"符号就是vim自动添加的。如果是在大量编写注释&#xff0c;…

WMI使用技巧集

WMI使用技巧集 很多的朋友对WMI可能见过但理解不深&#xff0c;我也是十分想了解关于WMI的知识&#xff0c;可一直找不对太合适的资料&#xff0c;在网上的一些资料不是有很多错误&#xff0c;就是讲解不清&#xff0c;我有空的时候将关于WMI的知识集中一下&#xff0c;放在这…

如果不被吐槽,那我还是程序员吗

一组漫画看看中美两国程序员的差别网友&#xff1a;不能更形象了... 本文原创公众号&#xff1a;不会笑青年 60专家&#xff0c;13个技术领域&#xff0c;CSDN 《IT 人才成长路线图》重磅来袭&#xff01;直接扫码或微信搜索「CSDN」公众号&#xff0c;后台回复关键词「路线图」…

Symantec BE 12.5 备份Exchange错误排除

备份时&#xff0c;提示以下错误&#xff1a;最终错误: 0xe0008703 - 作业失败于自身测试运行。解决方法&#xff1a;先备份本地的很小的文件&#xff08;不是测试备份&#xff09;&#xff0c;成功后&#xff0c;再测试Exchange的备份。以下是官网的详细解答。http://www.syma…

oc75--不可变字典NSDictionary

// // main.m // NSDictionary // //#import <Foundation/Foundation.h>int main(int argc, const char * argv[]) {// 1.如何创建NSDictionary *dict1 [NSDictionary dictionaryWithObject:"lnj" forKey:"name"];NSString *name1 [dict1 object…

特殊SQL语句及优化原则

1.按姓氏笔画排序:Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as 2.数据库加密:select encrypt(原始密码)select pwdencrypt(原始密码)select pwdcompare(原始密码,加密后密码) 1--相同&#xff1b;否则不相同 encrypt(原始密码)select pw…

以AI制作AI,当AutoML加入AI研究员内卷大潮

导读&#xff1a;「深度赋智」首推以知识驱动的全自动机器学习架构&#xff0c;应用于2020四月结束的国际自动机器学习领域的顶级赛事 NeurIPS-AutoDL竞赛&#xff0c;并以压倒性优势获得世界冠军&#xff0c;相关论文于近日被人工智能顶刊IEEE TPAMI接收。 「深度赋智」一直专…

oracle 导入数据

1.在数据库中建立实例数据库之后&#xff0c;运行cmd 2.键入 imp空格&#xff08;实例数据库名)/(实例数据库口令)空格file“拖入数据地址” 比如czt.dmp文件直接拖进去(空格)fully 3.按enter建转载于:https://www.cnblogs.com/dieyaxianju/p/3593522.html

C#隐藏手机号中间四位为*

使用正则&#xff1a;Regex.Replace(手机号, "(\\d{3})\\d{4}(\\d{4})", "$1****$2"); 效果&#xff1a;

FTP命令大全

文件传输软件的使用格式为&#xff1a;FTP<FTP地址>&#xff0c;若连 接成功&#xff0c;系统将提示用户输入用户名及口令&#xff1a;LOGIN&#xff1a; (输入合法的用户名或者“ANONMOUS”)&#xff1a;PASSWORD&#xff1a; (输入合法的口令&#xff0c;若以“ANONMOU…

ecshop 缓存

2019独角兽企业重金招聘Python工程师标准>>> 1、加缓存&#xff1a; if ($act list) {$cache_id event_list;/* 如果没有缓存&#xff0c;生成缓存 */if (!$smarty->is_cached(event.dwt, $cache_id)){$smarty->assign(page_title, 限量抢购_.$GLOBALS[_CFG…

打造数字原生引擎,易捷行云EasyStack发布新一代全栈信创云

作为新基建的基石&#xff0c;信息技术应用创新产业正迎来黄金发展期。作为企业数字化转型的核心平台, 信创云对下承载包括芯片、整机、操作系统等软硬件基础设施&#xff0c;对上支撑大数据、人工智能、物联网、5G等新一代企业级应用&#xff0c;在整个信创产业链体系中起到承…

第一章 软件自动化测试的基础知识

测试工具以及测试方法并不能代表自动化测试&#xff0c;大多数人提到自动化测试&#xff0c;都会说会使用什么工具或者什么技术&#xff0c;这完全是错误的&#xff0c;和我在刚接触的时候一样&#xff0c;以为掌握了Selenium/QTP就以为自己是一名自动化测试工程师了&#xff0…

Request.ServerVariables获取环境变量

Request.ServerVariables("HTTP_X_FORWARDED_FOR") 透过代理服务器取得客户端的真实IP地址&#xff0c;有些用此方法读取到的仍然是代理服务器的IP。还有一点需要注意的是&#xff1a;如果客户端没有通过代理服务器来访问&#xff0c;那么取到的值将是空的。 Request…

Java虚拟机JVM学习06 自定义类加载器 父委托机制和命名空间的再讨论

Java虚拟机JVM学习06 自定义类加载器 父委托机制和命名空间的再讨论 创建用户自定义的类加载器 要创建用户自定义的类加载器&#xff0c;只需要扩展java.lang.ClassLoader类&#xff0c;然后覆盖它的findClass(String name)方法即可&#xff0c;该方法根据参数指定的类的名字&a…

腾讯千帆战略升级,推出企业应用连接器

4月26日&#xff0c;腾讯在北京举行“2021腾讯千帆战略发布会”&#xff0c;解读其SaaS生态战略&#xff0c;并面向行业和客户发布了“企业应用连接器”。 2019年&#xff0c;腾讯发布千帆计划1.0&#xff0c;两年之后&#xff0c;这个涵盖腾讯SaaS生态的计划已经进化到2.0。与…

游戏角度分析产品

2019独角兽企业重金招聘Python工程师标准>>> 游戏角度分析 1:减少用户时间成本 - 碎片化的时间可玩 2:减少用户学习成本 - 操作够简单 3:增强用户的范围 - 操作够简单 -> 儿童,女生大量增加 4:增强用户骚浪体验 - 炫耀的快感 5:增强游戏物品的稀确性 - 花钱也买不…

EXCEL数据导入数据库

1、类设计&#xff0c;EXCEL要据配置读入DATASET using System;using System.Data;using System.Collections;using System.Data.OleDb; namespace HKH.Common{ /// <summary> /// Excel 表格中 列标头 与 列索引 的对应转换 /// </summary> /// <remarks>…

免费正则表达式辅助工具(转)

免费正则表达式辅助工具 前段时间由于工作需要&#xff0c;学了一天的正则表达式&#xff0c;发现正则表达式功能实在是强大&#xff0c;但是也很奇怪&#xff0c;刚接触会很不习惯。我不需要很深入地了解&#xff0c;所以也没学多久&#xff0c;不过找了几款很不错的免费的正则…

@所有人,CSDN 粉丝专属福利来啦!

属于CSDN粉丝专属福利来了&#xff01;不一样的专属福利&#xff0c;只属于少数人的免费计算资源&#xff01;即日起&#xff0c;并行科技联袂CSDN针对社区粉丝&#xff0c;推出“免费算力限时领”活动&#xff0c;新用户填写表单&#xff0c;即可获得“5000核时CPU或500元卡时…

算法:快速排序实现 定制比较函数

1. 快速排序基本算法 1 #include<stdio.h>2 const static int NUM 47; 3 4 int quick_sort(int *a, int start, int end){5 if (start > end) 6 return 0; 7 8 int partition a[start]; //分割点value, 设置为第一个点.最后patition点设置为这个…

人民币大小写转换

using System;using System.Text;using System.Text.RegularExpressions; namespace HKH.Common{ /// <summary> /// 人民币大小写格式转换 /// </summary> /// <remarks> Create By Lwt on 2006/09/23 /// </remarks> public class clsRMB { privat…

冒泡排序(java实现)

冒泡排序&#xff0c;就是每次遍历都会把最小(或者最大)的数放在前面。比如要升序{A1,........An} 第一次排序要取出整个数组中最小放在A1的位置&#xff0c;从An开始往前遍历&#xff0c;相邻两个数比较&#xff0c;如果Aj < Aj-1 则换位。知道比较到A1 这一趟完事之后 A…

好看又好用的 GUI,你需要这七个 Python 必备库,

来源 | 法纳斯特头图 | 下载于ICphotoGUI(图形用户界面)&#xff0c;顾名思义就是用图形的方式&#xff0c;来显示计算机操作的界面&#xff0c;更加方便且直观。与之相对应的则是CUI(命令行用户交互)&#xff0c;就是常见的Dos命令行操作&#xff0c;需要记忆一些常用的命令&a…

总结PHP 7新增加的特性

?? 运算符&#xff08;NULL 合并运算符&#xff09; 把这个放在第一个说是因为我觉得它很有用。用法&#xff1a; $a $_GET[a] ?? 1;它相当于&#xff1a; <?PHP $a isset($_GET[a]) ? $_GET[a] : 1; 我们知道三元运算符是可以这样用的&#xff1a; $a ?: 1但是这是…

谈“云”色变?近80%企业曾遭受数据泄露

出品 | 《大咖来了》 一边是企业上云这一毋庸置疑的发展趋势&#xff0c;但另一边&#xff0c;云数据泄露事件的频繁&#xff0c;却让不少企业谈“云”色变。 2020年2月&#xff0c;万豪酒店520万客人信息被泄露&#xff0c;英国信息专员办公室(ICO)对其进行了1840万英镑(约1.…

C语言的32个关键字

C语言的关键字共有32个&#xff0c;根据关键字的作用&#xff0c;可分其为数据类型关键字、控制语句关键字、存储类型关键字和其它关键字四类。1 数据类型关键字&#xff08;12个&#xff09;&#xff1a; (1) char &#xff1a;声明字符型变量或函数 (2) double &#xff1a;声…