ccf 201712-4 行车路线

解题思路:

  首先Dijkstra是基于贪心算法的,即每一次作出的选择都具有贪心选择性。此题由于有“如果连续走小道,小明的疲劳值会快速增加,连续走s公里小明会增加s2的疲劳度。”这种情况,所以不能使用Dijkstra算法。

  这里使用Bellman-Ford算法

70分备份待修改:

 #include<iostream>
#include<cstring>
using namespace std;
int n,m;//n为路口的数量,m为道路的数量
const int maxn = + ;
const int maxm = + ;
const int INF = ;//无穷大
struct node{
int ci,cj;
int type;
int cij;
}path[*maxm]; int Edge[maxn][maxn];//记录两个点之间路径的编号
int dist[maxn];//记录源点1到每一个节点的最短路
int pro[maxn];//记录每一个节点的前驱结点 void bellman()
{
memset(dist,INF,sizeof(dist));
dist[] = ;
memset(pro,-,sizeof(pro));
pro[] = ;//1没有前驱
for(int k=;k<n;k++)///进行n-1次松弛操作
{
bool flag = false;
for(int i=;i<*m;i++)
{
if(path[i].type == )//大道
{
if(dist[path[i].cj] > dist[path[i].ci]+path[i].cij)
{
dist[path[i].cj] = dist[path[i].ci]+path[i].cij;
pro[path[i].cj] = path[i].ci;
flag = true;
}
} else{//小道
//首先要计算出连续走小路多长时间
int con = path[i].cij;
int temp = i;
if(pro[path[i].ci] != - && pro[path[i].ci] != )//已经加入,有前驱
{ int pathnum = Edge[pro[path[temp].ci]][path[temp].ci];
while( path[pathnum].type == )//连续走小道
{
con += path[pathnum].cij;
temp = Edge[pro[path[temp].ci]][path[temp].ci];
if(pro[path[pathnum].ci] == ) break;//到达起始结点
pathnum = Edge[pro[path[temp].ci]][path[temp].ci];
} }
if(dist[path[i].cj]>dist[path[temp].ci] + con*con)
{
dist[path[i].cj]=dist[path[temp].ci] + con*con;
pro[path[i].cj] = path[i].ci;
flag = true;
}
}
}
if(!flag) break;
}
} int main()
{ while(cin>>n>>m)
{
for(int i=;i<*m;i++)
{
cin>>path[i].type>>path[i].ci>>path[i].cj>>path[i].cij;
i++;
path[i].ci = path[i-].cj;path[i].cj = path[i-].ci;
path[i].cij = path[i-].cij;path[i].type = path[i-].type;
Edge[path[i].ci][path[i].cj] = i;
Edge[path[i].cj][path[i].ci] = i-;
} bellman();
cout<<dist[n]<<endl;
}
return ;
}

ccf 201712-4 行车路线(70分)的更多相关文章

  1. ccf 201712-4 行车路线(Python实现)

    一.原题 问题描述 试题编号: 201712-4 试题名称: 行车路线 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 小明和小芳出去乡村玩,小明负责开车,小芳来导航. 小芳将 ...

  2. 洛谷P4559 [JSOI2018]列队 【70分二分 + 主席树】

    题目链接 洛谷P4559 题解 只会做\(70\)分的\(O(nlog^2n)\) 如果本来就在区间内的人是不用动的,区间右边的人往区间最右的那些空位跑,区间左边的人往区间最左的那些空位跑 找到这些空 ...

  3. 「PKUSC2018」星际穿越 (70分做法)

    5371: [Pkusc2018]星际穿越 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 27  Solved: 11[Submit][Status] ...

  4. 洛谷P1979 华容道(70分 暴力)

    P1979 华容道 题目描述 [问题描述] 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少 ...

  5. 洛谷P1081 开车旅行70分

    https://www.luogu.org/problem/show?pid=1081 太遗憾了明明写出来了,却把最小值初始值弄小了,从第二个点开始就不可能对了.70分! #include<io ...

  6. 华容道 noip2013 70分搜索

    题目描述 [问题描述] 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少需要多少时间. 小 ...

  7. ccf 201712-4 行车路线(30分超时)

    问题描述 小明和小芳出去乡村玩,小明负责开车,小芳来导航. 小芳将可能的道路分为大道和小道.大道比较好走,每走1公里小明会增加1的疲劳度.小道不好走,如果连续走小道,小明的疲劳值会快速增加,连续走s公 ...

  8. 【CCF CSP】 20171203 行车路线 Java(有问题)80分

    问题描述 小明和小芳出去乡村玩,小明负责开车,小芳来导航. 小芳将可能的道路分为大道和小道.大道比较好走,每走1公里小明会增加1的疲劳度.小道不好走,如果连续走小道,小明的疲劳值会快速增加,连续走s公 ...

  9. ccf 行车路线

    问题描述 小明和小芳出去乡村玩,小明负责开车,小芳来导航. 小芳将可能的道路分为大道和小道.大道比较好走,每走1公里小明会增加1的疲劳度.小道不好走,如果连续走小道,小明的疲劳值会快速增加,连续走s公 ...

随机推荐

  1. java三大框架——Struts + Hibernate + Spring

    Struts主要负责表示层的显示 Spring利用它的IOC和AOP来处理控制业务(负责对数据库的操作) Hibernate主要是数据持久化到数据库 再用jsp的servlet做网页开发的时候有个 w ...

  2. docker 卸载旧版本

    列出docker安装过的相关包: sudo yum list installed | grep docker 删除相关安装包 sudo yum -y remove docker-ce.x86_64su ...

  3. Use pkgsrc on ARM

    What is this page? This page describes how to use pkgsrc on ARM architecture with EABI support. I bo ...

  4. 招商银行网银在Mac上装了插件仍然无法登录

    1 装完插件后,在登录页面重新载入插件,再次打开

  5. linux 网卡相关命令

    1. ifconfig //查看网络相关信息 2. ifconfig eth0 192.168.1.103 netmask 255.255.255.0 //配置eth0的IP地址 3. route - ...

  6. bisect:维护一个有序的列表

    介绍 bisect模块实现了一个算法来向列表中插入元素,同时仍然保证列表有序 有序插入 import bisect ''' 可以使用bisect.insort向一个列表中插入元素 ''' values ...

  7. 1.Netty 实战前言

    1.参考文档:Netty实战精髓篇 2.Netty介绍:     Netty是基于Java NIO的网络应用框架. Netty是一个NIO client-server(客户端服务器)框架,使用Nett ...

  8. zabbix 自定义Key (六)

    1.在zabbix_agent端zabbix_agentd.conf配置文件中增加自定义Key(/usr/local/zabbix_agent/etc/zabbix_agentd.conf) ### ...

  9. 天线basic

    1.实际应用时,按内置天线还是外置天线考虑. 内置时,净空区在 PCB 上所有层(all layer) 不能放置元件,走线和铺 GND  天线远离金属,至少要距离周围有较高的元器件 10 毫米以上: ...

  10. mysql-mmm实现高可用和部署时须要考虑的问题

    mysql-mmm简介 Multi-Master Replication Manager for MySQL,简称mmm,官方的介绍可以参考mmm官网.好处自然不用说,读写分离,官方称读能做到负载均衡 ...