posts - 7, comments - 13, trackbacks - 0, articles - 37
   :: 首页 :: 新随笔 :: 联系 ::  :: 管理

[导入]PKU-1860

Posted on 2008-10-16 15:15 岁月流逝 阅读(210) 评论(0)  编辑 收藏 引用
题意 : 就是套汇的问题,汇率Rab, 增加了一个手续费  Cab 。。。。。。。每次的结果是  (本金 - 手续费) * 汇率,而且一个人拥有的钱的类型是已知的,拥有的value 钱的个数也是已知的, 问你能不能增值。
输入 :
3 2 1 20.0                         //钱种类个数  汇率的个数,拥有第几种钱, 拥有多少钱1 2 1.00 1.00 1.00 1.00            //钱a, 钱b, rab, cab, rba, cba2 3 1.10 1.00 1.10 1.00
算法:判断有无正环,采用bellman的最大路的松弛法去做.PS:要注意两个条件的跳出:1.有正环会不停的松弛,只要>val后叫结束循环.2.一旦不能循环了就结束循环,这是返回dist[s]>val就可以了

#include<stdio.h>
#include<memory.h>
struct node
{
  int u,v;
  double r,c;
};
int n,m,s;
double val;
node edge[1001];
int eg;
#define eps 1e-8
bool bellman()
{
  double dist[102];
  memset(dist,0,sizeof(dist));
  int i;
  int flag = 0;
  dist[s] = val;
  while(dist[s]<=val+eps)
  {
    flag  = 0;
    for(i = 0;i<=eg;i++)
    {
      if(dist[edge[i].v]+eps<(dist[edge[i].u]-edge[i].c)*edge[i].r)
      {
        dist[edge[i].v] = (dist[edge[i].u]-edge[i].c)*edge[i].r;
        flag=1;
      }
    }
    if(!flag)
      return dist[s]>val;
  }
  return true;
}
int main()
{
  int i;
  int a,b;
  double rab, cab, rba ,cba;
  while(scanf("%d %d %d %lf",&n,&m,&s,&val)!=EOF)
  {
    eg  = 0;
    for(i = 0;i<m;i++)
    {
      scanf("%d %d %lf %lf %lf %lf",&a,&b,&rab,&cab,&rba,&cba);
      edge[eg].u = a;
      edge[eg].v = b;
      edge[eg].r = rab;
      edge[eg].c = cab;
      eg++;
      edge[eg].u = b;
      edge[eg].v = a;
      edge[eg].r = rba;
      edge[eg].c = cba;
      eg++;
    }
    if(bellman())
    {
      printf("YES\n");
    }
    else
    {
      printf("NO\n");
    }
  }
  return 0;
}

Tags - , ,
文章来源:http://www.feng5166.com/blog/read.php?125

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理