要不我先去写T2吧(逃

先把题目搞上来:

【问题描述】 有 n 个城市,编号 1~n。其中 i 号城市的繁华度为 pi。省内有 m 条可以双向同行的高速 公路,编号 1~m。编号为 j 的高速公路连接编号为 aj 和 bj 两个城市,经过高速公路的费用 是 wj。若从城市 x 出发到某城市 y,除了需要缴纳高速公路费用,还要缴纳“城市建设费” (为从 x 城市到 y 城市所经过的所有城市中繁华度的最大值,包括 x 和 y 在内)。

现提出 q 个询问,每个询问给出一组 x 和 y,你需要回答从 x 出发到 y 城市,所需要的 最低交通费(高速公路费+城市建设费)是多少。

【输入】

第一行三个整数 n,m,q。 第二行 n 个整数,表示 p1~pn。

接下来 m 行中,每行 3 个正整数,第 j 行包含 Aj,Bj,Wj。

随后 Q 行每组两个正整数 x,y 表示一组询问。

【输出】

共 Q 行,为对 Q 个问题的回答:x 城市到 y 城市的最小交通费用。

【样例输入】

5 7 2

2 5 3 3 4

1 2 3

1 3 2

2 5 3

5 3 1

5 4 1

2 4 3

3 4 4

1 4

2 3

【样例输出】

8 9

【数据范围及约定】

n≤250,m≤20000,Q≤10000,Pi≤10000,Wj≤2000,保证任意两个城市可以互相到达。

【样例说明】 图中,代表城市的格子中第一个数字是城市编号,第二个红色数字是该城市的繁华度。

(1)从城市 1 到城市 4 的最小交通费用路线是:1 3 5 4;公路费是 2+1+1=4;城市建设费是 max{2,3,4,3}=4;总交通费用 4+4=8。

(2)从城市 2 到城市 3 的最小交通费用路线是:2 5 3;公路费是 3+1=4;城市建设费是 max{5,4,3}=5;总交通费用 4+5=9。


(跑回来补锅:

SOLUTION:

  1. 首先当然是存图啦,这里用邻接矩阵存图就好了。但是你以为这么容易的吗,你永远想想不到毒瘤出题人是怎么想的,这套题的数据点居然两个城市之间有超过一条的路径???慌得一批,这数据也是毒瘤的没谁了;
  2. 接下来是一些跑floyd的初始化:因为要加繁华度,因此我们要开两个二维数组来分别记录只最短路和加了繁华度的最短路;对于只记录最短路的二维数组a[i][j],用memset初始化为一个很大的数,在楼上存图时记得更新某两点间有一条路径(顺序写反了但是不想改),接下来顺带讲一下memset的赋值是怎么赋的:
    • memset按位赋值:一位等于8字节(一个int型是4位),(一字节可以看做是二进制中的一位),对于memset,无论你这个数是什么,它都会把每一位都变成第一位的数,如果我们用memset赋值1的话,最后结果就是这个数:

(一个蓝框为1位)

而本题中memset(a,63,sizeof(a));就是把a数组的初始值赋成了以下这个数:

好了继续讲初始化:初始化a[i][i]=0(自己到自己显然是0),用一个数组t[i]来记录下标,讲t数组按繁华度从小到大排序(讲真的这个排序我是第一次见/果真还是我太蒟了吗qwq)

这样我们来看一看样例排序后:也就是现在t[1]---t[n]分别对应着繁华度最低的城市的编号到繁华度最高的城市的编号;

预处理f[i][j]=a[i][j]+max(p[i],p[j]);这样如果两城市之间本来就有路联通的话,那么可以先被更新掉,如果不连通,可以近似的看为INF;

3.最核心的floyd部分,也是大家讨论了好久的部分:

    1. floyd实际上是一个DP(floyd:哈哈想不到吧qwq)
    2. floyd其实是一个三维DP
    3. floyd其实就跟01背包一样把k这一维降掉了,因此k要放在最外层枚举;
    4. 对于没有降维的三维floyd disk,i,j来讲,表示的是从i=>j只可能经过1——k这些点的最短路径;
    5. 对于这个题来讲:f[k][i][j]表示的就是从i=>j只可能经过1——k这前k个繁华福低的城市,因为这里枚举的k其实枚举的是第k的最不繁华城市,所以此时k城市一定是1——k中繁华度最高的,因此对于f[i][j]来说,此时要加的繁华度就是i城市,j城市和k城市中最大的一个;

4.最后就是输入询问然后直接输出f[x][y]就好啦

(撒花✿✿ヽ(°▽°)ノ✿)

#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
#include<algorithm>
using namespace std;
int n,m,q,p[],aj,bj,wj,x,y,f[][],a[][],top,t[];
int cmp(int x,int y)
{
return p[x]<p[y];
}
int main()
{
memset(a,,sizeof(a));
top=;
scanf("%d%d%d",&n,&m,&q);
for(int i=;i<=n;i++)
scanf("%d",&p[i]);
for(int i=;i<=m;i++)
{
scanf("%d%d%d",&aj,&bj,&wj);
a[aj][bj]=min(a[aj][bj],wj);
a[bj][aj]=min(a[bj][aj],wj);//据说是防止出现aj到bj有两条路的情况呀
//记录从aj到bj有一条路径,从bj到aj有一条路径(因为 双向通行)
}
for(int i=;i<=n;i++)
{
a[i][i]=;//自己到自己显然有一条为0的最短路
t[i]=i;//这里好像是防止排序后找不到哪个是哪个下标吧??
}
sort(t+,t++n,cmp);
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
f[i][j]=a[i][j]+max(p[i],p[j]);//先初始化最短路为这两点间的距离+这两点中p较大的p值
for(int k=;k<=n;k++)//floyd
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
{
a[i][j]=min(a[i][j],a[i][t[k]]+a[t[k]][j]);//干求最短路
f[i][j]=min(f[i][j],a[i][j]+max(p[i],max(p[j],p[t[k]])));
}
for(int i=;i<=q;i++)
{
scanf("%d%d",&x,&y);
printf("%d\n",f[x][y]);
}
return ;
}

nice end-

【6.12校内test】T3 城市交通费的更多相关文章

  1. 6.12友谊赛T4城市交通费题解

    与普通的最短路径不同的是,题目中新引入了一个计入总体的费用——城市建设费.由于城市建设费由整体的某最大值决定,导致解没有最优子结构的性质,给思维带来难度. 既然最棘手的是城市建设费,我们就对它分类讨论 ...

  2. 2019.7.9 校内测试 T3 15数码问题

    这一次是交流测试?边交流边测试(滑稽 15数码问题 大家应该都玩过这个15数码的游戏吧,就在桌面小具库那里面哦. 一看到这个题就知道要GG,本着能骗点分的原则输出了 t 个无解,本来以为要爆零,没想到 ...

  3. 18清明校内测试T3

    扫雷(mine) Time Limit:1000ms   Memory Limit:128MB 题目描述 rsy最近沉迷于一款叫扫雷的游戏. 这个游戏是这样的.一开始网格上有n*m个位置,其中有一些位 ...

  4. 2019.6.28 校内测试 T3 【音乐会】道路千万条

    大眼一看最下面的题意解释的话,发现这和洛谷P1310表达式的值挺像的,大概都是给定一些运算符号,让最后的表达式为true的概率,为false的概率啥的QwQ~: 然后这个题嘛?就是在所有的运算符中提溜 ...

  5. 【6.12校内test】T1单词序列

    [问题描述] 给出两个单词(开始单词和结束单词)以及一个词典.找出从开始单词转换到结束单词, 所需要的最短转换序列.转换的规则如下: 1.每次只能改变一个字母 2.转换过程中出现的单词(除开始单词和结 ...

  6. 【6.12校内test】T2 子集

    这道题大概是这三道题里最简单的啦 但这阻止不了我废的脚步 [问题描述] 对于 n=4 时,对应的集合 s={4,3,2,1},他的非空子集有 15 个依次如下: {1} {2} {1,2} {3} { ...

  7. MY TESTS

    励志整理所有的n次考试的博客: [五一qbxt]test1 [五一qbxt]test2 [校内test]桶哥的问题 [6.10校内test] noip模拟 6.12校内test [6.12校内test ...

  8. 【洛谷p1781】宇宙总统

    宇宙总统[题目链接] 关于题目算法,其实就是考排序,那我们直接sort不就好啦,显然不能. 这个题让我重新认识了cmp函数: 以下是我的心路历程: 看到这个题,嗯?这么简单的吗,我直接sort不就好啦 ...

  9. Floyed(floyd)算法详解

    是真懂还是假懂? Floyed算法:是最短路径算法可以说是最慢的一个. 原理:O(n^3)的for循环,对每一个中间节点k做松弛(寻找更短路径): 但它适合算多源最短路径,即任意两点间的距离. 但sp ...

随机推荐

  1. CMD命令行基本命令

    基本知识 输入 功能 Alt+Enter 全屏 Ctrl+S 暂停输出 Ctrl+C Ctrl+Break 停止程序 Ctrl+Z 表示输入结束 <file 从文件读标准输入 >file ...

  2. UVA 12063 Zeros and ones 一道需要好好体会的好题

    #include<bits/stdc++.h> #include<stdio.h> #include<iostream> #include<cmath> ...

  3. CodeForces451E Devu and Flowers

    题目链接 问题分析 没有想到母函数的做法-- 其实直接看题思路挺简单的.发现如果每种花都有无限多的话,问题变得十分简单,答案就是\(s+n-1\choose n - 1\).然后发现\(n\)只有\( ...

  4. python学习之路(8)

    定义函数 在Python中,定义一个函数要使用def语句,依次写出函数名.括号.括号中的参数和冒号:,然后,在缩进块中编写函数体,函数的返回值用return语句返回. 我们以自定义一个求绝对值的my_ ...

  5. Java并发编程的艺术笔记(五)——Java中的锁

    一.Lock接口的几个功能: 显示的获取和释放锁 尝试非阻塞的获取锁 能被中断的获取锁 超时获取锁 使用方式: Lock lock = new ReentrantLock(); lock.lock() ...

  6. TreeMap元素必须实现Comparable接口

    纠正一下,TreeMap实现一定顺序是通过Comparable接口的,而他实现元素不重复也是完全通过compareTo,而不是hashCode和equals,因为debug不会走到hashCode和e ...

  7. MqttConnectReturnCode枚举值

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  8. 2019秋Java学期课程总结

    眨眼间,Java这门课程就快要到了尾声,这门课程主要学习到 搭建了Java的编译环境,安装eclipse软件,会用Java写一些简单的程序. 主要学习到的知识点有以下几点 1:通过写pta上的作业知道 ...

  9. echarts+json笔记

    echart_test.html <!DOCTYPE html> <head> <meta charset="utf-8"> <scrip ...

  10. PHP 页面中实现数据的增删改查

    main页面(主页面) <table width="100%" border="1" cellpadding="0" cellspac ...