NOIP 2005 校門外的樹

2021-08-22 19:38:20 字數 1163 閱讀 2789

題目描述

某校大門外長度為l的馬路上有一排樹,每兩棵相鄰的樹之間的間隔都是1公尺。我們可以把馬路看成乙個數軸,馬路的一端在數軸0的位置,另一端在l的位置;數軸上的每個整數點,即0,1,2,...,l,都種有一棵樹。 

由於馬路上有一些區域要用來建地鐵。這些區域用它們在數軸上的起始點和終止點表示。已知任一區域的起始點和終止點的座標都是整數,區域之間可能有重合的部分。現在要把這些區域中的樹(包括區域端點處的兩棵樹)移走。你的任務是計算將這些樹都移走後,馬路上還有多少棵樹。 

輸入每組輸入資料的第一行有兩個整數l(1<=l<=10000)和m(1<=m<=100),l代表馬路的長度,m代表區域的數目,l和m之間用乙個空格隔開。接下來的m行每行包含兩個不同的整數,用乙個空格隔開,表示乙個區域的起始點和終止點的座標。 

資料規模: 

對於20%的資料,區域之間沒有重合的部分; 

對於其它的資料,區域之間有重合的情況。 

輸出每組輸出包括一行,這一行只包含乙個整數,表示馬路上剩餘的樹的數目。

分析:一看資料範圍直接暴力,對於需要移走的區間直接標記為o(1e6),最後統計沒被標記的o(1e4),總的就是o(1e6+1e4)。 

#include#include#include#include#include#include#include#include#include#include#include#include#include#include#define clear(x) memset(x,0,sizeof(x))

#define fup(i,a,b) for(int i=a;ib;i--)

#define rfdn(i,a,b) for(int i=a;i>=b;i--)

typedef long long ll;

typedef unsigned long long ull;

using namespace std;

const int maxn =1e4+7;

int vis[maxn];

int read()

while(ch>='0'&&ch<='9')

return f*ret;

}int main()

}rfup(i,0,l)

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

return 0;

}

NOIP2005 普及組 校門外的樹

題目鏈結 題目描述 某校大門外長度為 l 的馬路上有一排樹,每兩棵相鄰的樹之間的間隔都是 1 公尺。我們可以把馬路看成乙個數軸,馬路的一端在數軸 0 的位置,另一端在 l 的位置 數軸上的每個整數點,即 0,1,2,l,都種有一棵樹。由於馬路上有一些區域要用來建地鐵。這些區域用它們在數軸上的起始點和...

校門外的樹(NOIP2005複賽 普及組 第二題)

總時間限制 1000ms 記憶體限制 65536kb 描述 某校大門外長度為l的馬路上有一排樹,每兩棵相鄰的樹之間的間隔都是1公尺。我們可以把馬路看成乙個數軸,馬路的一端在數軸0的位置,另一端在l的位置 數軸上的每個整數點,即0,1,2,l,都種有一棵樹。由於馬路上有一些區域要用來建地鐵。這些區域用...

校門外的樹

描述 某校大門外長度為 l的馬路上有一排樹,每兩棵相鄰的樹之間的間隔都是 1公尺。我們可以把馬路看成乙個數軸,馬路的一端在數軸 0的位置,另一端在 l的位置 數軸上的每個整數點,即0,1,2 l,都種有一棵樹。馬路上有一些區域要用來建地鐵,這些區域用它們在數軸上的起始點和終止點表示。已知任一區域的起...