| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 388 人关注过本帖
标题:让人蛋疼的问题,long long 都搞不定
只看楼主 加入收藏
love24114
Rank: 5Rank: 5
等 级:职业侠客
威 望:1
帖 子:223
专家分:399
注 册:2011-7-11
结帖率:81.48%
收藏
已结贴  问题点数:20 回复次数:2 
让人蛋疼的问题,long long 都搞不定
图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册

求思路求代码
2011-12-28 14:54
czz5242199
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:660
专家分:2400
注 册:2011-10-26
收藏
得分:10 
将区间按左位置排序,然后统计

还有一种方法就是先把坐标离散话,然后再按照之前的方法处理,这个你可以自己差资料

[ 本帖最后由 czz5242199 于 2011-12-28 15:09 编辑 ]
2011-12-28 14:57
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:10 
程序代码:
#include <stdio.h>
#include <stdlib.h>
struct Node
{
    int start;
    int end;
};

int cmp(const void *pa,const void *pb)
{
    return ((Node *)pa)->start - ((Node *)pb)->start;
}
Node list[105];
int main()
{
    int l,m;
    int i,j,k;
    while(EOF != scanf("%d%d",&l,&m))
    {
        for(i = 0;i<m;i++)
            scanf("%d%d",&list[i].start,&list[i].end);
        qsort(list,m,8,cmp);
        int max = list[0].end;
        int lost = list[0].start;
        for(i = 1;i<m;i++)
        {
            if(list[i].start > max)
            {
                lost += list[i].start-max-1;
                max = list[i].end;
            }
            else if(list[i].end > max)
                max = list[i].end;
        }
        printf("%d\n",lost+l-max);
    }
    return 0;
}


http://acm.swust.   感谢曹兄弟的思路

                                         
===========深入<----------------->浅出============
2011-12-28 20:16
快速回复:让人蛋疼的问题,long long 都搞不定
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.033625 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved