Cod sursa(job #1001753)

Utilizator paunmatei7FMI Paun Matei paunmatei7 Data 25 septembrie 2013 22:49:02
Problema Farfurii Scor 10
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.78 kb
#include<stdio.h>
#include<vector>

using namespace std;

vector<int> a;
int n, m;

int main(){
    freopen("farfurii.in", "r", stdin);
    freopen("farfurii.out", "w", stdout);
    scanf("%d %d", &n, &m);
    int Sum;
    for(Sum = 1; Sum * (Sum + 1) / 2 <= m; ++ Sum);
    -- Sum;
    m -= (Sum * (Sum + 1)) / 2;
    if(m > 0){
        for(int i = 1; i <= n - Sum - 2; ++ i)
            a.push_back(i);
        a.push_back(n - Sum + 1);
        for(int i = n; i >= n - Sum - 1; -- i)
            if(i != n - Sum + 1)
                a.push_back(i);
    }
    else{
        for(int i = 1; i < n - Sum; ++ i)
            a.push_back(i);
        for(int i = n; i >= n - Sum; -- i)
            a.push_back(i);
    }
    for(int i = 0; i < a.size(); ++ i)
        printf("%d ", a[i]);
    return 0;
}