POJ 3621 Sightseeing Cows | 01分数规划

本文提供了一种解决POJ 3621问题的有效方法,通过结合二分查找和SPFA算法来判断是否存在负权回路,并给出了完整的C++代码实现。

题目:

http://poj.org/problem?id=3621


题解:

二分答案,检查有没有负环

#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 1005
using namespace std;
struct node
{
    int nxt,v;
    double w;
}e[N*5];
int head[N],ecnt,L,P;
double dis[N],fun[N],l,r,mid;
bool vis[N];
void add(int u,int v,int w)
{
    e[++ecnt].v=v;e[ecnt].w=w;e[ecnt].nxt=head[u];head[u]=ecnt;
}
bool spfa_dfs(int u,double val)
{
    vis[u]=1;
    for (int i=head[u],v;i;i=e[i].nxt)
    {
    if (dis[v=e[i].v]>dis[u]+e[i].w*val-fun[u])
    {
        dis[v]=dis[u]+e[i].w*val-fun[u];
        if (!vis[v]) {if (spfa_dfs(v,val)) return 1;}
        else return 1;
     }
    }
    vis[u]=0;
    return 0;
}
bool check(double mid)
{
    memset(vis,0,sizeof(vis));
    memset(dis,0,sizeof(dis));
    for (int i=1;i<=L;i++)
    if (spfa_dfs(i,mid)) return 1;
    return 0;
}
int main()
{
    scanf("%d%d",&L,&P);
    for (int i=1;i<=L;i++)
    scanf("%lf",&fun[i]),r+=fun[i];
    for (int i=1,u,v,c;i<=P;i++)
    scanf("%d%d%d",&u,&v,&c),add(u,v,c);
    for (int i=1;i<=50;i++)
    {
    mid=(l+r)/2.0;
    if (check(mid)) l=mid;
    else r=mid;
    }
    printf("%.2f\n",l);
    return 0;
}

 

转载于:https://www.cnblogs.com/mrsheep/p/8256791.html

(1)求职者端(Web 前端) 岗位浏览与搜索: 智能推荐首页:基于 “专业背景 + 求职意向” 推荐匹配岗位(如 “计算机专业硕士” 优先推荐 “高校计算机教师岗”“实验员岗”),展示岗位核心信息(学校名称、岗位名称、薪资范围、截止日期)。 多条件筛选:支持按 “岗位类型(教学岗 / 科研岗 / 行政岗)、学历要求(硕士 / 博士)、地区(华北 / 华东等)、学校层次(985/211 / 双非)” 组合筛选,结果按 “匹配度 / 发布时间 / 薪资” 排序。 岗位详情页:展示 “岗位职责、任职要求、福利待遇、应聘流程、联系人信息”,提供 “收藏岗位、一键投递简历、查看该岗位竞争热度(如‘已有 230 人投递’)” 功能。 个人求职中心: 简历管理:支持创建多版本简历(如 “教学岗专用简历”“科研岗专用简历”),包含 “基本信息、教育经历、科研成果、教学经验、获奖情况” 等模块,支持 PDF 导出和在线编辑。 应聘跟踪:记录 “已投递岗位、简历状态(已接收 / 筛选中 / 面试通知 / 已录用)、截止日期提醒”,对 “3 天内即将截止的岗位” 自动推送提醒。 竞争分析:针对已投递岗位,展示 “求职者学历分布(博士占比 75%)、专业匹配度排名(你的匹配度 85 分,超过 80% 竞争者)”,辅助评估自身竞争力。 (2)高校招聘负责人端(Web 管理端) 岗位管理: 岗位发布:填写 “岗位名称、招聘人数、学历要求、专业方向、岗位职责、薪资范围、应聘方式” 等信息,支持上传 “岗位说明书附件”,设置 “自动截止日期” 和 “简历接收邮箱”。 批量操作:对 “已过期岗位” 进行批量下架,对 “热门岗位(投递量>100)” 设置 “自动置顶”,支持 “岗位信息批量导出(Excel 格式)”。 简历筛选: 智能初筛:系统自动对投递简历进行 “匹配度评分”
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值