哈哈哈哈,我就知道这道题目再扔给我,我还是不会,就是这么菜,哈哈哈

一开始官方题解就没搞懂…然后就看了一下别人的代码,水水过就算了。今天拿到…GG;

题意:

一开始,有一张原图,有一条长度为n的链. 节点i和i+1之间有长度为1的边.

现在又新加了3条边, 每条边长度都是1. 给出m个询问, 每次询问两点之间的最短路.

然后让你算出对于每组数据, 输出一个整数S=(∑i=1mi⋅zi) mod (109+7), 其中zi表示第i

组询问的答案.

官方题解:

你可以选择分类讨论, 但是估计可能会写漏一些地方. 只要抽出新增边的端点作为关键点, 建立一个新图, 然后跑一遍floyd就好了. 复杂度大概O(6^2⋅m)

然后继续摸着摸着发现,也可以说是感觉到。

我们在一个用领接矩阵所存储的图中,求一个点到一个点的最短距离,无非就是min(两点间直接多长,点1经过一些最短路到达点2);

这一题让我体会很多:

第一:

利用一个图来进行操作,那么无可厚非这个图里面点之间的距离就是最短距离。建图啊建图,这只是个初始化的过程,在第二遍拿起这道题的时候还是错了。

第二:

利用图这个过程,那么就是经过与不经过的问题;还有这道题目让我体会最深的就是怎么经过,在纸上画了一下,瞬间爆炸,我floyd的精华一点都不知道啊!

过程,过程!!!

这道题目显示了自己:1,基础差! 2,floyd算法没理解!还是太菜,太菜。

#include<cstdio>
#include<stdlib.h>
#include<string.h>
#include<iostream>
using namespace std;
typedef long long LL;
LL mod=1e9+7;
LL INF=0x3f3f3f3f;
int n;
LL bmap[10][10];
LL cp[110]; void init()
{
for(int i=0; i<6; i++)
{
for(int j=0; j<6; j++)
{
bmap[i][j]=bmap[j][i]=abs(cp[i]-cp[j]);
}
}
} void debug()
{
for(int i=0; i<6; i++)
{
for(int j=0; j<6; j++)
printf("%d ",bmap[i][j]);
printf("\n");
}
} void floyd()
{
int k,i,j;
for(k=0; k<6; k++)
{
for(i=0; i<6; i++)
{
for(j=0; j<6; j++)
{
bmap[i][j]=min(bmap[i][j],bmap[i][k]+bmap[k][j]);
}
}
}
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int num;
scanf("%d%d",&n,&num);
for(int i=0; i<6; i++)
{
scanf("%d",&cp[i]);
}
init();
bmap[0][1]=bmap[1][0]=1;
bmap[2][3]=bmap[3][2]=1;
bmap[4][5]=bmap[5][4]=1; //建图,要想在一张图上进行操作,则所必须的就是保证这张图就是最完美(最短路)的图,所以跑一下floyd;
floyd(); // debug(); LL ans=0;
for(int p=1; p<=num; p++)
{
int u,v;
scanf("%d%d",&u,&v);
LL sum=abs(u-v); for(int i=0; i<6; i++)
{
for(int j=0; j<6; j++) //跑一跑最短路
{
sum=min(sum,abs(u-cp[i])+abs(v-cp[j])+bmap[i][j]);
sum=min(sum,abs(v-cp[i])+abs(u-cp[j])+bmap[i][j]);
}
}
ans=(ans+(p*sum)%mod)%mod;
}
printf("%lld\n",ans);
}
return 0;
}

BestCoder Round #74 (div.1) 1002Shortest Path(hdoj5636)的更多相关文章

  1. hdu 5636 搜索 BestCoder Round #74 (div.2)

    Shortest Path  Accepts: 40  Submissions: 610  Time Limit: 4000/2000 MS (Java/Others)  Memory Limit: ...

  2. hdu5635 BestCoder Round #74 (div.2)

    LCP Array  Accepts: 131  Submissions: 1352  Time Limit: 4000/2000 MS (Java/Others)  Memory Limit: 13 ...

  3. BestCoder Round #67 (div.2) N bulbs(hdu 5600)

    N bulbs Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Su ...

  4. Codeforces Round #368 (Div. 2) B. Bakery (模拟)

    Bakery 题目链接: http://codeforces.com/contest/707/problem/B Description Masha wants to open her own bak ...

  5. BestCoder Round #74 (div.2)

    组合 1001 LCP Array 第一题就小难,出题的好像是浙大的大牛? 找到一个规律:a[i] = x, s[i..i+x]都想同.a[i] = a[i+1] + 1 (a[i] > 0), ...

  6. hdu 5637 BestCoder Round #74 (div.2)

    Transform  Accepts: 7  Submissions: 49  Time Limit: 4000/2000 MS (Java/Others)  Memory Limit: 131072 ...

  7. HDU5638 / BestCoder Round #74 (div.1) 1003 Toposort 线段树+拓扑排序

    Toposort   问题描述 给出nn个点mm条边的有向无环图. 要求删掉恰好kk条边使得字典序最小的拓扑序列尽可能小. 输入描述 输入包含多组数据. 第一行有一个整数TT, 表示测试数据组数. 对 ...

  8. Codeforces Round #284 (Div. 2) C题(计算几何)解题报告

    题目地址 简要题意: 给出两个点的坐标,以及一些一般直线方程Ax+B+C=0的A.B.C,这些直线作为街道,求从一点走到另一点需要跨越的街道数.(两点都不在街道上) 思路分析: 从一点到另一点必须要跨 ...

  9. Codeforces Round #262 (Div. 2) 460C. Present(二分)

    题目链接:http://codeforces.com/problemset/problem/460/C C. Present time limit per test 2 seconds memory ...

随机推荐

  1. JAVA设计模式之 原型模式【Prototype Pattern】

    一.概述: 使用原型实例指定创建对象的种类,而且通过拷贝这些原型创建新的对象. 简单的说就是对象的拷贝生成新的对象(对象的克隆),原型模式是一种对象创建型模式. 二.使用场景: 创建新的对象能够通过对 ...

  2. 九度OJ #1437 To Fill or Not to Fil

    题目描写叙述: With highways available, driving a car from Hangzhou to any other city is easy. But since th ...

  3. 爬虫-UserAgent

    废话不多说,直接写代码 [root@localhost ~]# pip3 install fake-useragent Collecting fake-useragent Downloading ht ...

  4. mac classpath设置

    I've been searching for the answer daylong, and finally had the problems solved. I am going to write ...

  5. 基于HTML5 Canvas和jQuery 的绘图工具的实现

    简单介绍 HTML5 提供了强大的Canvas元素.使用Canvas并结合Javascript 能够实现一些很强大的功能.本文就介绍一下基于HTML5 Canvas 的绘图工具的实现.废话少说,先看成 ...

  6. UI UISearchBar UISearchDisplayController实现搜索条、解析颜色

    本文转载至 http://blog.sina.com.cn/s/blog_bf2d33bd01017q6l.html @interface ThirdViewController : UIViewCo ...

  7. python day- 16 面向对象

    1.类的相关知识 类:是指具有相同属性和技能的一类事物. 比如:人类 ,植物类,动物类,狗类. 对象:是类中的某一个实例,是类的具体表现. 比如:具体到某个人,某一个植物,某一条狗. class 是p ...

  8. sanic官方文档解析之蓝图

    1,蓝图(Blueprints) 蓝图可用于子路由的应用,代替增加路由的存在,蓝图的定义和增加路由的方法相似,灵活的在应用中注册,并且可插拔的方式. 尤其是在大型应用中使用蓝图的时候在你逻辑打断的地方 ...

  9. 文件批量转换成UTf-8

    yum install -y enca 在文件夹根目录下面创建文件:iconv_shell.sh 里面填写下面的内容: #!/bin/bash for file in `find ./ -name ' ...

  10. 百度dureos CMake Error

    CMake Error: CMAKE_C_COMPILER not set, after EnableLanguage CMake Error: CMAKE_CXX_COMPILER not set, ...