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 }
时间: 2024-10-11 03:37:30

P1194 买礼物的相关文章

洛谷P1194 买礼物

洛谷P1194 买礼物在买了第一次之后,你还要买 n-1次,把所有点都连起来,这样做一个最小生成树就行了,然后要注意题目中说了如果a[ i ][ j ]==0 则表示两个点是不相连的,赋值 inf 最后还要注意一下一开连第一条边是需要A的 1 #include <bits/stdc++.h> 2 #define LL long long 3 #define For(i,j,k) for(int i=j;i<=k;i++) 4 using namespace std ; 5 6 const

洛谷——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,那么表

luogu 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,那么表示这两样东西之间不会

2017广东工业大学程序设计竞赛决赛-tmk买礼物

tmk买礼物 Description 今天是校赛的日子,为了庆祝这么喜庆的日子,TMK打算买些礼物给女票LSH庆祝一下. TMK进入了雪梨超市,然后刚踏入的一瞬间,店主就对TMK说:“恭喜你成为了本店第2147483647位顾客,本店在搞一个活动,对本店第2147483647位顾客进行赠送活动.你先看看你有多少钱?” TMK一摸口袋,发现只有n个硬币,每个硬币的价值为a[i]. 然后店主继续说:“现在你用你的钱凑一些数,如果你的钱能凑成[0,x]里面所有的数,那么你将会免费获得该店价值x元的代金

程序员从来没给丈母娘买礼物,真相竟然令人沉默

同事A,程序员,今年三十左右,已婚,有一女儿,技术好,开发经验足,平时工作也很勤奋,来公司两年,头发逐渐秃顶. 一日闲聊,A和我们抱怨,快要过年了,要给丈母娘准备礼物了.丈母娘老是跟他老婆抱怨A没有给自己买过礼物. 我们问他:"那你到底有没有买过礼物嘛?" A说:"没有买过." 我们都很惊讶:"你怎么从来不买礼物啊?多多少少都会买点吧,你这样别人肯定有意见了,哪有女婿从来不给岳父岳母买礼物的?" A又说:"我也想不到买什么,所以没买,但

Luogu 1194买礼物

题意:买n个东西,这些东西有个原价m,若买东西i,则东西j降到a[i][j]元,求买n个东西最少的钱. 做法:若买i后买j的价钱a[i][j]比m小,那么连一条无向边,跑一波最小生成树. 看剩下还有几个点没连进去的就直接按原价买.. 1 #include <iostream> 2 #include <cstdio> 3 #include <algorithm> 4 #include <cstring> 5 #include <cmath> 6 #

洛谷——买礼物

这题只要建一个虚点0,建B条连向0的边,权为A AB皆为题目给出的 #include<iostream> #include<cstdio> #include<algorithm> using namespace std; const int maxn=510,maxm=300010; struct edge{int f,t,c;}e[maxm]; bool cmp(edge a,edge b){return a.c<b.c;} int fa[maxn],n,m=0

2017 9 24

当前最好成绩: noip2016 初赛32.5 模拟赛(3):140 模拟赛(6):270 评级:零 今天继续模拟,一上来用自己的公式A掉了T1,然后看了看T3看不懂题,也不知道样例怎么来的,于是一上午都在肝T2,写了一个暴力Floyd,n^3的时间复杂度,而且常数大的一批,然而过掉了300的数据.还写了20分的特殊情况,不知道什么原因炸掉了,只得了40分,加上T1一共有140分,加上day1就有270分了,双刷新最高纪录... 其余时间继续是图论,今天似乎是最小生成树专场,各种最小生成树的改编

微信幼儿园投票刷礼物活动,你有被投票的经历吗?

朋友间的帮忙拉拉票就行,但是这件事要是到了自己身上就不是那么简单了,今天我姐的孩子参加幼儿园投票活动,让给拉拉票,自己投完了还要去群里发一圈好友发一遍,票数不够还要心甘情愿的买礼物,关键是下面买礼物的人还显示,不买还不行,当时心想这个一个孩子刷200元的礼物,50个孩子最起码也要上万啊,这生意绝了! 我小侄女的幼儿园人多,200个小盆友左右,平时她在班级表现的比较积成绩也比较优秀,经常得到老师的夸奖,最近圆里面搞了个最美宝贝评选大赛,活动浏览量接近100万人次,应该还不错:幼儿园说是别人给免费搞