zoukankan      html  css  js  c++  java
  • CodeForce 517 Div 2. C Cram Time

    http://codeforces.com/contest/1072/problem/C

    C. Cram Time
    time limit per test
    1 second
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    In a galaxy far, far away Lesha the student has just got to know that he has an exam in two days. As always, he hasn't attended any single class during the previous year, so he decided to spend the remaining time wisely.

    Lesha knows that today he can study for at most aa hours, and he will have bb hours to study tomorrow. Note that it is possible that on his planet there are more hours in a day than on Earth. Lesha knows that the quality of his knowledge will only depend on the number of lecture notes he will read. He has access to an infinite number of notes that are enumerated with positive integers, but he knows that he can read the first note in one hour, the second note in two hours and so on. In other words, Lesha can read the note with number kk in kkhours. Lesha can read the notes in arbitrary order, however, he can't start reading a note in the first day and finish its reading in the second day.

    Thus, the student has to fully read several lecture notes today, spending at most aa hours in total, and fully read several lecture notes tomorrow, spending at most bb hours in total. What is the maximum number of notes Lesha can read in the remaining time? Which notes should he read in the first day, and which — in the second?

    Input

    The only line of input contains two integers aa and bb (0a,b1090≤a,b≤109) — the number of hours Lesha has today and the number of hours Lesha has tomorrow.

    Output

    In the first line print a single integer nn (0na0≤n≤a) — the number of lecture notes Lesha has to read in the first day. In the second line print nn distinct integers p1,p2,,pnp1,p2,…,pn (1pia1≤pi≤a), the sum of all pipi should not exceed aa.

    In the third line print a single integer mm (0mb0≤m≤b) — the number of lecture notes Lesha has to read in the second day. In the fourth line print mm distinct integers q1,q2,,qmq1,q2,…,qm (1qib1≤qi≤b), the sum of all qiqi should not exceed bb.

    All integers pipi and qiqi should be distinct. The sum n+mn+m should be largest possible.

    Examples
    input
    Copy
    3 3
    output
    Copy
    1
    3
    2
    2 1
    input
    9 12
    output
    2
    3 6
    4
    1 2 4 5
    Note

    In the first example Lesha can read the third note in 33 hours in the first day, and the first and the second notes in one and two hours correspondingly in the second day, spending 33 hours as well. Note that Lesha can make it the other way round, reading the first and the second notes in the first day and the third note in the second day.

    In the second example Lesha should read the third and the sixth notes in the first day, spending 99 hours in total. In the second day Lesha should read the first, second fourth and fifth notes, spending 1212 hours in total.

    题意:

     有无数多个lecture note,标号为1,2,3,4,5... 他们复习所要花费的时间和标号大小相同。分两天复习这些lecture。每天的复习小时不一样,求分配使得复习的lecture最多。

    思路:

    首先a,b分开装东西,不会比他们合在一起装东西装的多。(反证法)

    其次,如果从大到小枚举可行的lecture note,如果每次先考虑a,那么a最后肯定可以被装满。

    所以,剩下的lecture note,给b,b一定装的下所有。

    代码:

     1 #include <iostream>
     2 #include <cstring>
     3 #include <algorithm>
     4 #include <cmath>
     5 #include <cstdio>
     6 #include <vector>
     7 #include <queue>
     8 #include <set>
     9 #include <map>
    10 #include <stack>
    11 #define ll long long
    12 #define local
    13 
    14 using namespace std;
    15 
    16 const int MOD = 1e9+7;
    17 const int inf = 0x3f3f3f3f;
    18 const double PI = acos(-1.0);
    19 const int maxn = (1e5+10);
    20 const int maxedge = 100*100;
    21 ll a, b;
    22 
    23 int main() {
    24 #ifdef local
    25     if(freopen("/Users/Andrew/Desktop/data.txt", "r", stdin) == NULL) printf("can't open this file!
    ");
    26 #endif
    27     
    28     scanf("%lld%lld", &a, &b);
    29     vector <ll> ansa, ansb;
    30     ll x = 1;
    31     for (; 1LL*x*(x+1)/2 <= a+b; ++x) ;
    32     x--;
    33     for (; x > 0; x--) {
    34         if (a >= x) {
    35             ansa.push_back(x);
    36             a -= x;
    37         } else if (b >= x) {
    38             ansb.push_back(x);
    39             b -= x;
    40         }
    41     }
    42     printf("%d
    ", int(ansa.size()));
    43     for (int i = 0; i < ansa.size(); ++i) {
    44         printf("%lld", ansa[i]);
    45         if (i != ansa.size()-1) printf(" ");
    46     }
    47     cout << endl;
    48     printf("%d
    ", int(ansb.size()));
    49     for (int i = 0; i < ansb.size(); ++i) {
    50         printf("%lld", ansb[i]);
    51         if (i != ansb.size()-1) printf(" ");
    52     }
    53     cout << endl;
    54     
    55 #ifdef local
    56     fclose(stdin);
    57 #endif
    58     return 0;
    59 }
    View Code
  • 相关阅读:
    xml 转义特殊字符
    MySql按周,按月,按日分组统计数据
    js jquery 动态添加表格
    详解Oracle partition分区表
    DBMS_NETWORK_ACL_ADMIN (OCP 053 第七题)
    RMAN 的优缺点及RMAN 备份及恢复步骤
    完美解决xhost +报错: unable to open display "" 装oracle的时候总是在弹出安装界面的时候出错
    Linux系统(X64)7 安装Oracle11g完整安装图文教程另附基本操作
    11g新特性-SQL Plan Management
    Oracle中事务处理控制用法
  • 原文地址:https://www.cnblogs.com/lecoz/p/9833990.html
Copyright © 2011-2022 走看看