ÀÛ¼ºÀÏ : 18-05-21 00:07
2012 Áß2 Àü½ÃÀå
 ±Û¾´ÀÌ : ¾çÁøÇõ(yangjh05)
Á¶È¸ : 2,612  
#include <stdio.h>
#include <stdlib.h>
#include <algorithm>

using namespace std;

struct picture{
    int h;
    int money;
}H[300100];

int ptr = -1;
int N, S;
int D[300100];

bool cmp(picture A, picture B){
    return A.h < B.h;
}

int Fd_max(int HM){
    if(HM < H[0].h) return ptr = -1;
    if(ptr == -1) ptr = 0;
    for(int i = ptr; i < N; i++){
        if(HM < H[i].h) return ptr = i - 1;
    }
}

int max(int a, int b){
    return a < b? b : a;
}

void Fl_dyn(){
    D[0] = H[0].money;
    for(int i = 1; i < N; i++){
        int X = Fd_max(H[i].h - S);
        if(X == -1) D[i] = max(D[i - 1], H[i].h);
        else {
            int x = ptr;
            D[i] = max(D[i - 1], D[x] + H[i].money);
        }
    }
}

int main()
{
    scanf("%d %d", &N, &S);
    for(int i = 0; i < N; i++){
        scanf("%d %d", &H[i].h, &H[i].money);
    }
    sort(H, H + N, cmp);
    Fl_dyn();
    printf("%d\n", D[N - 1]);
    return 0;
}
//¼±»ý´ÔÀÌ °­ÀÇÇØÁֽŴë·Î Äڵ带 Â¥ ºÃ´Âµ¥¿ä... ¾îµð°¡ Ʋ·Á¼­ 30Á¡Àϱî¿ä?

ÄĽºÄð 18-05-24 21:30
 
¿­½ÉÈ÷ Çϸ鼭 ½Ç·Âµµ »ó´çÈ÷ ´Ã°í Àִ°Š°°½À´Ï´Ù.
ÇÏÁö¸¸ »ç¼ÒÇÑ ¿À·ù´Â °¡´ÉÇÏ¸é µð¹ö±ëÀ» ÅëÇØ ½º½º·Î ¹®Á¦¸¦ ãÀ¸·Á°í ³ë·ÂÀ» ÇØ¾ß ÇÕ´Ï´Ù.
±×·¯Áö ¾Ê°í¼­´Â ÇѰ踦 ¹þ¾î³¯ ¼ö ¾ø½À´Ï´Ù.

if(X == -1) D[i] = max(D[i - 1], H[i].h);
ÀÌ ºÎºÐ¿¡¼­ H[i].h°¡ ´«¿¡ µé¾î¿À³×¿ä.
°°Àº ½ÄÀÇ ´Ù¸¥ °÷¿¡¼­´Â H[i].money¸¦ ½è´Âµ¥ µÑ Áß Çϳª´Â À߸øµÈ °ÍÀÌ°ÚÁö¿ä?
 
 

Total 662
¹øÈ£ Á¦   ¸ñ ±Û¾´ÀÌ ³¯Â¥ Á¶È¸
642 ¼ö°­½Åû ÇÑ µÚ ÀÔ±ÝÇÏ¿´´Âµ¥ 󸮰¡ ¾ÈµÇ¼­ ½ÅûÃë¼ÒÇÏ¿´½À´Ï´Ù¡¦ (1) ¼­Á¤È¯ 09-05 1795
641 254p ¶È°°ÀÌ ÀÔ·Â ÈÄ ÄÚµùÇϴµ¥ Àß ¾ÈµÇ³×¿ä (1) ±èÀºÁÖ 07-21 2003
640 ÀÚ°¡ÁÖµµ C¾ð¾î ¹è¿­2 - ÀÚ°¡Áø´Ü 1 P196 (1) Ȳ¼¼¿µ 07-20 1786
639 ¹Ýº¹Á¦¾î3 ÀÚ°¡Áø´Ü5 ¾î¶»°Ô ÇØ¾ß Çϳª¿ä?? Ȳ¼¼¿µ 07-17 1762
638    ¹Ýº¹Á¦¾î3 ÀÚ°¡Áø´Ü5 ¾î¶»°Ô ÇØ¾ß Çϳª¿ä?? (2) ±è´ëÀÍ 07-17 1787
637 ÀÚ±âÁÖµµc¾ð¾î/ÆÄÀ̽ã ÇÁ·Î±×·¡¹Ö ±³»ç¿ë ´ä¾ÈÁö ±è´ëÀÍ 07-15 2608
636 ¹Ýº¹Á¦¾î¹®2 7´Ü¿ø p140 ÀÚ°¡Áø´Ü 6¹®Á¦ÀÔ´Ï´Ù. (7) Ȳ¼¼¿µ 07-15 1651
635    ¹Ýº¹Á¦¾î¹®2 7´Ü¿ø p140 ÀÚ°¡Áø´Ü 6¹®Á¦ÀÔ´Ï´Ù. (1) ±è´ëÀÍ 07-15 1766
634 ¼ö°­·á ÀÔ±ÝÇÏ¿´½À´Ï´Ù ±èÁ¤¼ö 06-07 1769
633 ¼ö°­·á ÀÔ±ÝÇÏ¿´½À´Ï´Ù. À̿빫 04-19 1980
632 °áÁ¦ °ü·Ã ÁúÀÇ À̿빫 04-19 1852
631 ÀÚ±âÁÖµµ C ¾ð¾î Ã¥ ¸»°í ´Ù¸¥Ã¥ ¾È½Â¹Î 03-24 2090
630 ÀÚ±âÁÖµµ C¾ð¾î ÇÁ·Î±×·¡¹Ö °­ÀǺ¸±â (1) ÀÌ¹Î±Ô 02-17 2174
629 ÀÚ±âÁÖµµ C¾ð¾î ÇÁ·Î±×·¡¹Ö (1) ±èÁö¿ì 02-15 2030
628 °áÁ¦ Çß½À´Ï´Ù. (1) ¿øÅ°æ 10-19 2256
627 °áÁ¦ È®ÀκÎŹµå·¯¿ä ¶ó¼±³à 09-10 2358
626 °áÀçÇß½À´Ï´Ù Ãֹμ® 08-21 2428
625 ÀÚ±âÁÖµµ C¾ð¾î ÇÁ·Î±×·¡¹Ö (2) ±è¹ÎÁö 08-20 2848
624 »çÀÌÆ® ÁÖ¿ä Ãë¾àÁ¡ ÀÌ¿µÁØ 08-03 3036
623 ¿äÁò °­ÀÇ µè±â ¾î·Á¿ö¿ä À̿빫 07-29 2473
 1  2  3  4  5  6  7  8  9  10  11  12  13  14  15  16  17  18  19  20  21  22  23  24  25  26  27  28  29  30    

ȸ»ç¼Ò°³ | °³ÀÎÁ¤º¸Ã³¸®¹æħ | ÀÌ¿ë¾à°ü | ã¾Æ¿À½Ã´Â ±æ | À̸ÞÀÏÁÖ¼Ò ¹«´Ü¼öÁý°ÅºÎ | »ç¾÷ÀÚÁ¤º¸È®ÀÎ
°æ±âµµ ¾È¾ç½Ã µ¿¾È±¸ È£°èµ¿ 1065-10 Çù¼º°ñµåÇÁ¶óÀÚ 601È£ ÇÑÄÄ¿¡µàÄÉÀ̼Ç(ÁÖ) TEL : 031-388-8840 FAX : 031-388-0996
´ëÇ¥ÀÚ : ±èµ¿±Ô »ç¾÷ÀÚ¹øÈ£ : 130-86-02870 Åë½ÅÆǸž÷½Å°í¹øÈ£ : Á¦ 2010-°æ±â¾È¾ç-888È£
COPYTIGHT(C) ÇÑÄÄ¿¡µàÄÉÀ̼Ç(ÁÖ), ALL RIGHT RESERVED.
´ãÀº°­Á : 0