解题思路: 通过合并重叠区间方式计算,避免巨大数组

注意事项: 

总树木为长度+1 

挖掘树数为初始点-末尾点+1

设2个区间为a1~a2,b1~b2 判断重叠方法为b1<=a2 && b2>=a1


参考代码:

#include <stdio.h>

#define MAX(x,y) (x)>(y)?(x):(y)

#define MIN(x,y) (x)>(y)?(y):(x)


int main() {

     int length, num;

     int span[200] ; //每2个连续单元为一个区间

     scanf("%d%d", &length, &num); //输入长度和区间数量

     length++;//两头都有树 所以+1

     int i,j;

     for (i = 0; i < 200; i++) { //初始化 为-1 ,-1代表无数据

         span[i] = -1;

     }

     for (i = 0; i < num; i++) { //输入区间

         scanf("%d%d", &span[i * 2], &span[i * 2 + 1]);

     }

     for (i = 0; i < num; i++) {  //合并重叠区间

            for (j = 0; j < num; j++) {

                 if (span[j * 2] <= span[i * 2 + 1] && span[j * 2+1 ] >= span[i * 2] && i!=j) {      //判断重叠且不比较自身

                     span[i * 2] = MIN(span[i * 2], span[j * 2]); //合并

                     span[i * 2 + 1] = MAX(span[i * 2 + 1], span[j * 2 + 1]);

                     span[j * 2] = -1; //合并后清除被合并的区间

                     span[j * 2 + 1] = -1;

                 }

          }

     }

    

     for (i = 0; i < num; i++) { //计算剩余树木

         if(span[i * 2]!= -1)

             length -= span[i * 2 + 1] - span[i * 2]+1;

     }

     printf("%d\n", length);

     return 0;

}



点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论