URAL - 1078 Segments

题目大意:有n条线段,一个线段a 完全覆盖另一个线段b 当且仅当,a.l < b.l && a.r>b.r。问你

一个线段覆盖一个线段再覆盖一个线段再.......,问你最多几个线段属于这种关系,并打印出路径。

 

这题的的 n 太小了,n^3的方法都能过。

 

思路:1. 我们设dp[ i ] 为 以 i 位最外层的答案为多少,n^3的方法是,我们先将所有dp的值设为1,

枚举最外层的点,再枚举其内层的点更新,一次更新肯定是不够的,我们更新到它没有更新了再

退出,感觉和最短路的贝尔曼算法相似,这种方法显然复杂度很高。

 

2.第一种方法中我们显然是无脑地枚举边,怎么才能减少不必要的操作呢。我们将边按左端点的

大小排序,然后从后往前枚举最外层的点,因为是按左端点排序的而且是从后往前枚举,所以能

被当前点包含的肯定在该点的后面,这样我们每次更新当前点之后,当前点的dp值肯定是最优值,

这样我们就将复杂度降到了n^2。(虽然我排了序,但我是傻逼从前往后枚举,虽然优化了一点,还是n^3)

 

3.这是一个学姐的方法,也是复杂度应该也是n^2,我们将每条线段都看成一个点,然后如果一条

线段能包含另一条线段,我们就在他们之间连一条有向边。那么我们就从各个点出发,看每个点

到最深处的路径长度是多少,显然也能用记忆化搜索。(这个方法我感觉好牛逼啊)

 

这里贴一下第二种方法的代码吧QAQ

#include<bits/stdc++.h>
using namespace std;
const int N=505;
int n,pre[505],dp[505];
struct node
{
    int fi,se,id;
    bool operator < (const node &t)const
    {
        return fi<t.fi;
    }
}seg[505];
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++) scanf("%d%d",&seg[i].fi,&seg[i].se),seg[i].id=pre[i]=i;
    sort(seg+1,seg+n+1);
    for(int i=1;i<=n;i++) dp[i]=1;
    for(int i=n;i>=1;i--)
    {
        for(int j=i+1;j<=n;j++)
        {
            if(seg[j].fi>seg[i].fi && seg[j].se<seg[i].se && dp[i]<dp[j]+1)
            {
                dp[i]=dp[j]+1;
                pre[i]=j;
            }
        }
    }
    int mx=0,item;
    for(int i=1;i<=n;i++)
    {
        if(dp[i]>mx)
        {
            mx=dp[i];
            item=i;
        }
    }
    cout<<mx<<endl;
    vector<int> ans;
    ans.push_back(seg[item].id);
    while(item!=pre[item])
    {
        item=pre[item];
        ans.push_back(seg[item].id);
    }
    int len=ans.size();
    for(int i=len-1;i>=0;i--) printf("%d%c",ans[i],i==0 ? '\n':' ');
    return 0;
}
View Code

 

转载于:https://www.cnblogs.com/CJLHY/p/7354448.html

城市运行管理的重要性与挑战 城市运行体系是以人为本的服务和经济发展体系,涉及决策、管理和执行三个层次。当前城市运行管理面临城市化快速发展、资源环境制约和社会矛盾突出等挑战。信息技术的发展为城市运行管理提供了重要手段,城市信息化经历了数字化、智能化到智慧化的发展过程。我国城市信息化虽取得进展,但仍处于初级阶段,存在缺乏整体规划、资源浪费和协作效率不高等问题。 智慧城市综合运行管理解决方案 智慧城市运行管理中心(SCOC)是支撑城市运行综合管理的神经中枢,旨在掌控城市运行综合体征,促进服务型政府转型。该中心通过全面整合运行资源,服务城市未来发展,提升城市运行水平和突发事件处置效率。中心纵向提升综合职能,横向贯通专业分工,包括综合管理平台、专业管理平台和业务操作平台,覆盖城市交通、公共安全、生态环境等多个领域。 智慧城市综合运行管理平台的结构与功能 智慧城市综合运行管理平台包括决策支持系统、处置系统、基础设施和监测系统。平台通过综合展现系统、综合应急指挥系统、综合运行业务联动系统等,实现城市运行的综合监测和管理。物联网数据采集系统利用网络通讯技术,实现城市物联网设备的高效运行。平台还包含云计算业务支撑系统、城市基础数据库、视频图像云平台等,以支持城市运行管理的各个方面。 智慧城市综合运行管理解决方案的优势 该解决方案具有三个核心优势:首先,它提供了完整的智慧城市视角,不仅仅是指挥中心或数据中心,而是智慧城市的实际载体。其次,它建立了完整的城市运行联动体系,打通业务部门壁垒,形成有机融合的业务联动平台,提升业务处理效率和服务水平。最后,方案凝聚了多年智慧城市建设咨询经验,为城市运行管理提供了成熟的解决方案。 项目实施建议 智慧城市运行管理中心的建设思路和项目实施建议是方案的重要组成部分,旨在指导城市如何有效实施智慧城市运行管理解决方案,以应对城市运行管理的挑战,提升城市管理的智能化和效率。通过这些建议,城市能够更好地规划和实施智慧城市项目,实现可持续发展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值