0005-校門外的樹

問題描述

某校大門外長度為 L 的馬路上有一排樹,每兩棵相鄰的樹之間的間隔都是 1 米。我們可以把馬路看成一個數(shù)軸,馬路的一端在數(shù)軸 0 的位置,另一端在 L 的位置;數(shù)軸上的每個整數(shù)點,即 0,1,2,......,L,都種有一棵樹潜腻。由于馬路上有一些區(qū)域要用來建地鐵埃儿。 這些區(qū)域用它們在數(shù)軸上的起始點和終止點表示。 已知任一區(qū)域的起始點和終止點的坐標(biāo)都是整數(shù), 區(qū)域之間可能有重合的部分融涣。 現(xiàn)在要把這些區(qū)域中的樹(包括區(qū)域端點處的兩棵樹)移走童番。你的任務(wù)是計算將這些樹都移走后,馬路上還有多少棵樹。

輸入

輸入的第一行有兩個整數(shù) L(1 <= L <= 10000)和 M(1 <= M <= 100),L 代表馬路的長度,M 代表區(qū)域的數(shù)目,L 和 M 之間用一個空格隔開威鹿。接下來的 M 行每行包含兩個不同的整數(shù),用一個空格隔開,表示一個區(qū)域的起始點和終止點的坐標(biāo)剃斧。

輸出

輸出包括一行,這一行只包含一個整數(shù),表示馬路上剩余的樹的數(shù)目。

輸入樣列

500 3
150 300
100 200
470 471

輸出樣例

297

算法實現(xiàn)

using System;

namespace Questions{
    class Program{
        static void Main(string[] args){
            //輸入L M
            string input = Console.ReadLine();
            //格式轉(zhuǎn)換
            string[] str = input.Split(' ');
            int L = int.Parse(str[0]);
            int M = int.Parse(str[1]);
            int[] num = new int[M * 2];
            if (L >= 1 && L <= 10000 && M >= 1 && M <= 100){
                //循環(huán)M次獲取M行數(shù)據(jù)
                for (int i = 0; i < M; i++){
                    input = Console.ReadLine();
                    str = input.Split(' ');
                    num[2 * i] = int.Parse(str[0]);
                    num[2 * i + 1] = int.Parse(str[1]);
                    //如果輸入i行的數(shù)據(jù)忽你,第一個比第二個大這交換位置
                    if (num[2 * i] > num[2 * i + 1])
                        num[2 * i] = num[2 * i + 1] + (num[2 * i + 1] = num[2 * i]) * 0;
                    else if (num[2 * i] == num[2 * i + 1]){
                        Console.WriteLine("輸入錯誤幼东!");
                    }
                }

                //遍歷區(qū)域之間重合的部分
                for (int i = 0; i < M; i++){
                    for (int j = 0; j < i; j++){
                        if (num[2 * i + 1] <= num[2 * j + 1] && num[2 * i] >= num[2 * j]){
                            //[num[2 * i],num[2 * i+1]]被[num[2 * j],num[2 * j+1]]包含時
                            num[2 * i] = 0;
                            num[2 * i + 1] = 0;
                        }
                        else if (num[2 * i + 1] >= num[2 * j + 1] && num[2 * i] <= num[2 * j]){
                            //[num[2 * i],num[2 * i+1]]包含[num[2 * j],num[2 * j+1]]
                            num[2 * j] = 0;
                            num[2 * j + 1] = 0;
                        }
                        else if (num[2 * i + 1] <= num[2 * j + 1] && num[2 * i + 1] >= num[2 * j] && num[2 * i] < num[2 * j]){
                            //num[2 * i+1]在[num[2 * j],num[2 * j+1]]之間num[2 * i]小于num[2 * j]
                            num[2 * i + 1] = num[2 * j] - 1;
                        }
                        else if (num[2 * i] <= num[2 * j + 1] && num[2 * i] >= num[2 * j] && num[2 * i + 1] > num[2 * j + 1]){
                            //num[2 * i]在[num[2 * j],num[2 * j+1]]之間num[2 * i+1]大于num[2 * j+1]
                            num[2 * i] = num[2 * j + 1] + 1;
                        }
                    }
                }

                //計算移走的樹的數(shù)目
                int sum = 0;
                for (int i = 0; i < M; i++)
                {
                    //當(dāng)num[2 * i + 1] !=num[2 * i]時,該段有樹需要被 移走
                    if (num[2 * i + 1] !=num[2 * i])
                        sum += num[2 * i + 1] - num[2 * i] + 1;
                }
                sum = L - sum;
                Console.WriteLine(sum);
            }
            Console.ReadKey();
        }
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末科雳,一起剝皮案震驚了整個濱河市根蟹,隨后出現(xiàn)的幾起案子糟秘,更是在濱河造成了極大的恐慌,老刑警劉巖尿赚,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件凌净,死亡現(xiàn)場離奇詭異,居然都是意外死亡躲舌,警方通過查閱死者的電腦和手機(jī)性雄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進(jìn)店門秒旋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人迁筛,你說我怎么就攤上這事∥咀” “怎么了?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵翰苫,是天一觀的道長奏窑。 經(jīng)常有香客問我屈扎,道長,這世上最難降的妖魔是什么鹰晨? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任并村,我火速辦了婚禮滓技,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘膝昆。我一直安慰自己,他們只是感情好荚孵,可當(dāng)我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布收叶。 她就那樣靜靜地躺著共苛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪澄峰。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天俏竞,我揣著相機(jī)與錄音魂毁,去河邊找鬼。 笑死夺蛇,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的刁赦。 我是一名探鬼主播闻镶,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼铆农,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了墩剖?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤郊霎,失蹤者是張志新(化名)和其女友劉穎书劝,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體购对,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡骡苞,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年解幽,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片亚铁。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡徘溢,死狀恐怖吞琐,靈堂內(nèi)的尸體忽然破棺而出站粟,到底是詐尸還是另有隱情曾雕,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布切诀,位于F島的核電站搔弄,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏顾犹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一擎宝、第九天 我趴在偏房一處隱蔽的房頂上張望浑玛。 院中可真熱鬧,春花似錦失晴、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至栏账,卻和暖如春栈源,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背甚垦。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留闭翩,地道東北人。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓兑障,卻偏偏與公主長得像蕉汪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子者疤,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,834評論 2 345

推薦閱讀更多精彩內(nèi)容