USER: Kevin Samuel [kevin_s1]
TASK: comehome
LANG: C++ Compiling...
Compile: OK Executing...
Test 1: TEST OK [0.003 secs, 3376 KB]
Test 2: TEST OK [0.005 secs, 3376 KB]
Test 3: TEST OK [0.005 secs, 3376 KB]
Test 4: TEST OK [0.005 secs, 3376 KB]
Test 5: TEST OK [0.011 secs, 3376 KB]
Test 6: TEST OK [0.019 secs, 3376 KB]
Test 7: TEST OK [0.035 secs, 3376 KB]
Test 8: TEST OK [0.005 secs, 3376 KB]
Test 9: TEST OK [0.008 secs, 3376 KB] All tests OK. YOUR PROGRAM ('comehome') WORKED FIRST TIME! That's fantastic
-- and a rare thing. Please accept these special automated congratulations. very easy, it's a shortest path problem 建图时直接以A-Z和a-z作为节点建图,我用了一个简单的Dijkstra算法,从Z 点反向找近期的点
/*
ID:kevin_s1
PROG:comehome
LANG:C++
*/ #include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
#include <vector>
#include <map>
#include <set>
#include <algorithm>
#include <cstdlib>
#include <list>
#include <cmath> using namespace std; #define MAXN 53
#define INF 99999 //gobal variable==== int P;
int Graph[MAXN][MAXN];
int result;
int Dist[MAXN]; int visited[MAXN];
//================== //function==========
int Convert(char ch){
int index = -1;
if(ch >= 'A' && ch <= 'Z'){
index = ch - 'A' + 1;
}
else if(ch >= 'a' && ch <= 'z'){
index = ch - 'a' + 27;
}
else
index = -1;
return index;
} int Dijkstra(int v0){
int min;
int k;
//init
for(int i = 1; i < MAXN; i++){
visited[i] = false;
Dist[i] = Graph[v0][i];
}
Dist[v0] = 0;
visited[v0] = 1;
for(int v = 1; v < MAXN; v++){
min = INF;
for(int w = 1; w < MAXN; w++){
if(!visited[w] && (Dist[w] < min)){
min = Dist[w];
k = w;
}
}
visited[k] = 1;
for(int w = 1; w < MAXN; w++){
if(!visited[w] && (min + Graph[k][w] < Dist[w])){
Dist[w] = min + Graph[k][w];
}
}
}
int Min = INF;
for(int i = 1; i < MAXN; i++){
if(Dist[i] < Min && i >= 1 && i <= 26 && Dist[i] > 0){
Min = Dist[i];
result = i;
}
}
return Min;
} //================== int main(){
freopen("comehome.in","r",stdin);
freopen("comehome.out","w",stdout);
cin>>P; for(int i = 1; i < MAXN; i++){
Graph[i][i] = INF;
for(int j = 1; j < MAXN; j++){
Graph[i][j] = INF;
}
}
memset(visited, 0, sizeof(visited));
while(P--){
char chst, chen;
int dist;
cin>>chst>>chen>>dist;
int st = Convert(chst);
int en = Convert(chen);
if(dist < Graph[st][en]){
Graph[st][en] = dist;
Graph[en][st] = dist;
}
}
int ans = Dijkstra(26);
char chfarm = 'A' + result - 1;
cout<<chfarm<<" ";
cout<<ans<<endl;
return 0;
}

USACO comehome Dijkstra的更多相关文章

  1. Cogs 309. [USACO 3.2] 香甜的黄油 dijkstra,堆,最短路,floyd

    题目:http://cojs.tk/cogs/problem/problem.php?pid=309 309. [USACO 3.2] 香甜的黄油 ★★   输入文件:butter.in   输出文件 ...

  2. cogs 176. [USACO Feb07] 奶牛聚会 dijkstra

    176. [USACO Feb07] 奶牛聚会 ★☆   输入文件:sparty.in   输出文件:sparty.out   简单对比时间限制:3 s   内存限制:16 MB 译: zqzas N ...

  3. cogs 397. [USACO Oct09] 热浪 Dijkstra

    397. [USACO Oct09] 热浪 ★☆   输入文件:heatwvx.in   输出文件:heatwvx.out   简单对比时间限制:1 s   内存限制:128 MB 德克薩斯純樸的民眾 ...

  4. USACO 2008 January Silver Telephone Lines /// 二分最短路 邻接表dijkstra oj22924

    题目大意: 一共有N (1 ≤ N ≤ 1,000)个电线杆,有P P (1 ≤ P ≤ 10,000)对电线杆是可以连接的, 用几条线连接在一起的电线杆之间都可相互通信,现在想要使得电线杆1和电线杆 ...

  5. 【USACO 2.4 】Bessie Come Home

    题意:给出n条有权的双向边(10000),求到达Z最近的大写字母,及其距离. 题解:即求Z出发的最短路,用dijstra就可以了,注意边要开到20000以上. /* TASK: comehome LA ...

  6. 洛谷 P1529 回家 Bessie Come Home Label:Dijkstra最短路 && 乱搞

    题目描述 现在是晚餐时间,而母牛们在外面分散的牧场中. 农民约翰按响了电铃,所以她们开始向谷仓走去. 你的工作是要指出哪只母牛会最先到达谷仓(在给出的测试数据中,总会有且只有一只最快的母牛). 在挤奶 ...

  7. TYVJ P1031 热浪 Label:dijkstra 最短路

    背景 USACO OCT09 9TH 描述 德克萨斯纯朴的民眾们这个夏天正在遭受巨大的热浪!!!他们的德克萨斯长角牛吃起来不错,可是他们并不是很擅长生產富含奶油的乳製品.Farmer John此时以先 ...

  8. 8.8-8.10 usaco

    summary:44 没救了...整天刷水迟早药丸! ❤bzoj3892: 区间dp.我原来的思路是dp[i][j]表示前i个数跳过了j次,那么转移可以前k个数转移了j-1次,枚举k就好了,但是这样是 ...

  9. usaco silver

    大神们都在刷usaco,我也来水一水 1606: [Usaco2008 Dec]Hay For Sale 购买干草   裸背包 1607: [Usaco2008 Dec]Patting Heads 轻 ...

随机推荐

  1. [Java][Android][Process] ProcessBuilder与Runtime差别

    在Android中想要进行Ping,在不Root机器的情况下似乎还仅仅能进行底层命调用才干实现. 由于在Java中要进行ICMP包发送须要Root权限. 于是仅仅能通过创建进程来攻克了.创建进程在Ja ...

  2. Swift - 判断设备类型开发兼容的iOS应用(iPad使用分隔视图控制器)

    1,分割视图控制器(UISplitViewController) 在iPhone应用中,使用导航控制器由上一层界面进入下一层界面. 但iPad屏幕较大,通常使用SplitViewController来 ...

  3. Python天天美味(25) - 深入理解yield

    Python天天美味(25) - 深入理解yield - CoderZh - 博客园 Python天天美味(25) - 深入理解yield   yield的英文单词意思是生产,刚接触Python的时候 ...

  4. Linux入门基础 #10:命令行文本处理工具

    本文出自   http://blog.csdn.net/shuangde800 ------------------------------------------------------------ ...

  5. 使用HashMap须要注意的事儿:不要暴露Map.entry给外部不可信代码Map.entrySet()

    Map/HashMap是java中一种非经常常使用的数据结构,一般我们在应用中做的事情就是调用put向容器写入数据或者是get从容器读取数据. Map.entrySet()这种方法返回了键值对的集合, ...

  6. ACM-计算几何之Quoit Design——hdu1007 zoj2107

    Quoit Design Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) To ...

  7. XMPP协议简介

    XMPP(息处理现场协议)是基于可扩展标记语言(XML)的协议.它用于即时消息(IM)以及在线现场探測.XMPP协议採用的是client-server架构,全部从一个client发到还有一个clien ...

  8. 浅谈 PHP 神盾的解密过程

    原文:浅谈 PHP 神盾的解密过程 前些日子一个朋友丢了个shell给我,让我帮忙解密,打开源码看了下写着是 “神盾加密” , 牛逼闪闪的样子.百度下发现神盾是个很古老的东西,最后一次更新是在 201 ...

  9. 【瞎搞】 HDU 3101 The Heart of the Country

    比赛时愣是没读懂 题意:有N 个城市 每一个城市都有 val 个 士兵 , 有几条路连接 当敌方攻击你的某个城市时 该城市以及与该城市相连接的城市的士兵总数 要大于 K 不大于 K 该城市就被攻陷.士 ...

  10. 在html中写python代码的语法和特点-----基于webpy的httpserver

    在html文件里写python语法的内容,的注意事项: 1:python程序中的变量通过以下方法传入到html: 1:通过全局变量 :全局变量是不须要用$def with语法实现传递的,仅仅要定义了 ...