以前做过这套题目

这个题又重新写了:http://www.cnblogs.com/jh818012/archive/2013/05/05/3182681.html

还是以前的思路

一直错在一个地方:决策的时候,如果没有走过,直接更新,如果走过,总是选最小值。如果走的是小于mid值的边,那么用tmp = max(dp[x][u] , e[i].val) 更新。

代码比以前好多了好像、

#define maxn 1005

int dp[maxn][maxn];
int n,m,k;
struct node
{
int v,next;
int val;
int f;
};
node e[ * ];
int head[maxn];
int cnt ;
void init()
{
cnt = ;
memset(head,-,sizeof(head));
}
void add(int u,int v,int w)
{
e[cnt].v = v ;
e[cnt].val = w;
e[cnt].next = head[u] ;
head[u] = cnt ++ ; e[cnt].v = u ;
e[cnt].val = w ;
e[cnt].next = head[v];
head[v] = cnt ++ ;
return ;
}
bool vis[maxn]; void dfs(int u)
{
vis[u]= ;
for(int i = head[u]; i != - ; i = e[i].next )
if(!vis[e[i].v] )
dfs(e[i].v);
} queue< pair<int,int> > q;
#define pii pair<int,int>
bool vs[maxn][maxn]; void spfa()
{
pii cur,tt;
int u , x;
while(!q.empty()) q.pop();
dp[][] = ;
vs[][] = ;
q.push(make_pair(,));
while(!q.empty())
{
cur = q.front();
q.pop();
u = cur.first;
x = cur.second;
for(int i = head[u]; i != - ; i = e[i].next )
{
if(e[i].f == )
{
tt = make_pair(e[i].v , x + );
if(x + > k ) continue;
// printf("%d %d %d %d\n",u,x,e[i].v,x+1);
//int tmp = max(dp[e[i].v][x+1],dp[u][x]);
if((dp[e[i].v][x+] == - && dp[u][x] >= )|| ( dp[e[i].v][x+] != - && dp[u][x] >= && dp[u][x] < dp[e[i].v][x+] ) )
{
dp[e[i].v][x+] = dp[u][x] ;
if(!vs[tt.first][tt.second])
{
vs[tt.first][tt.second] = ;
q.push(tt);
}
}
}
else if(e[i].f == )
{
tt = make_pair(e[i].v,x);
if(x > k ) continue;
// printf("%d %d %d %d\n",u,x,e[i].v,x);
int tmp = max(e[i].val , dp[u][x] );
if(dp[e[i].v][x] == - || tmp < dp[e[i].v][x])
{
dp[e[i].v][x] = tmp;
if(!vs[tt.first][tt.second])
{
vs[tt.first][tt.second] = ;
q.push(tt);
}
}
}
}
vs[u][x] = ;
}
//if(dp[n][k] >= 0 ) puts("asjklsajk");
}
int check()
{
memset(dp,-,sizeof(dp));
memset(vs,,sizeof(vs));
spfa();
//printf("dp[n][k] = %d\n",dp[n][k]);
return dp[n][k];
}
void build(int x)
{
for(int i = ; i <= n ; i ++ )
{
for(int j = head[i] ; j != - ; j = e[j].next)
if(e[j].val > x )
e[j].f = ;
else e[j].f = ;
}
}
int _max;
int main()
{
int u,v,w;
while(scanf("%d%d%d",&n,&m,&k)!=EOF)
{
init();
_max = ;
for(int i = ; i <= m ; i ++ )
{
scanf("%d%d%d",&u,&v,&w);
_max = max(_max , w);
add(u,v,w);
}
dfs();
if(!vis[n])
{
printf("-1\n");
continue;
}
int left , right ,mid ;
left = ;
right = _max ;
int ans ;
int res;
ans = 0x3f3f3f3f;
while(left < right)
{
mid = (left + right ) / ;
//printf("mid = %d\n",mid);
build(mid);
res = check();
//printf("res = %d\n",res);
if(res == - )
{
// printf("%d\n",left);
left = mid + ;
}
else
{
ans = min(ans , res);
right = mid ;
}
}
printf("%d\n",ans);
}
return ;
} /*
8 10 2
1 2 1
1 3 10
2 3 2
3 4 11
3 5 3
4 5 10
4 8 12
4 6 9
5 7 4
6 7 5
*/

Telephone Lines USACO 月赛的更多相关文章

  1. USACO Telephone Lines

    洛谷 P1948 [USACO08JAN]电话线Telephone Lines https://www.luogu.org/problem/P1948 JDOJ 2556: USACO 2008 Ja ...

  2. poj 3662 Telephone Lines

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7115   Accepted: 2603 D ...

  3. POJ 3662 Telephone Lines【Dijkstra最短路+二分求解】

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7214   Accepted: 2638 D ...

  4. (poj 3662) Telephone Lines 最短路+二分

    题目链接:http://poj.org/problem?id=3662 Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total ...

  5. poj3662 Telephone Lines【最短路】【二分】

    http://poj.org/problem?id=3662 Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submi ...

  6. [POJ] 3362 Telephone Lines

    Telephone Lines Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7978 Accepted: 2885 Descr ...

  7. poj 3662 Telephone Lines(最短路+二分)

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6973   Accepted: 2554 D ...

  8. poj 3662 Telephone Lines dijkstra+二分搜索

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5696   Accepted: 2071 D ...

  9. BZOJ1614: [Usaco2007 Jan]Telephone Lines架设电话线

    1614: [Usaco2007 Jan]Telephone Lines架设电话线 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 892  Solved: ...

随机推荐

  1. FS SIP呼叫的消息线程和状态机线程

    THREAD 当收到一次呼叫的时候,FS会在TU层创建两个线程,一个线程为状态机线程,另外一个为消息线程.状态机线程通过switch_core_session_thread_launch创建,顾名思义 ...

  2. SSH三作品的框架和流程

    Hibernate工作的,为什么? 原理: 1.通过Configuration().configure();读取并解析hibernate.cfg.xml配置文件 2.由hibernate.cfg.xm ...

  3. SQL查询优化——数据结构设计

    本文部分内容会涉及mysql,可能在其它数据库中并不适用. 本章节仅仅针对数据库结构设计做讨论.查询优化的其它内容待续. 数据库设计及使用是WEB开发程序猿必备的一项基础技能,在大数据量和高并发场景, ...

  4. hdu 4944 FSF’s game(数论)

    题目链接:hdu 4944 FSF's game 题目大意:给定N,能够用不大于N的长a和宽b.组成N∗(N−1)2种不同的矩形,对于每一个矩形a∗b要计算它的值,K为矩形a,b能够拆分成若干个K∗K ...

  5. Android的第二次增加SurfaceView基本使用

    本文来源于http://blog.csdn.net/hellogv/ ,引用必须注明出处. 上次介绍MediaPlayer的时候略微介绍了SurfaceView,SurfaceView因为能够直接从内 ...

  6. ListView的cacheColorHint与listSelector物业和fragment里面onActivityResult问题没有响应

    fragment里面onActivityResult 如何才华被称之为.在使用时发现没反应,没注意这个问题谁. 多方法都不是非常方便.最终实验除了一个最简单的方法. startActivityForR ...

  7. 将EBS设为首页worklist删除误报

    参考:How To Remove Error Notifications From The Worklist (Doc ID 357904.1) 1.1. Use one of the error n ...

  8. MarkdownPad怎么显示表格

    工具 >选项 > Markdown >Markdown处理器 改为 “Markdown(扩展)”即可. 下载地址 http://www.xdowns.com/soft/1/95/20 ...

  9. hibernate它 10.many2many单向

    在前文hibernate之5.many2one单向提到多对多关系,表结构设计是基于中间表来实现, 以下以用户与角色(多对多)为例,在Hibernate是怎样操作的 表结构设计: 类图: CRUD; S ...

  10. UML 简单的总结

    上某一个地方,总有个记忆挥不散,每一个深夜某一个地方,总有着最深的思量- 都说岁月无情人有情,记忆easy催人老,可有时候反倒觉着人比岁月更无情.岁月留下了我们成长的印记,但是有时候以前认为会相伴永远 ...