제출 #1324358

#제출 시각아이디문제언어결과실행 시간메모리
1324358aritro_선물 (IOI25_souvenirs)C++20
39 / 100
12 ms400 KiB
#include<bits/stdc++.h>
//#include "souvenirs.h"
using namespace std;

typedef long long ll;
//#define int ll
#define endl '\n'
#define pb push_back
#define ff first
#define ss second
#define all(a) a.begin(),a.end()

const int MOD=1000000007;

#define gcd(a,b) __gcd(a,b)
#define lcm(a,b) (a*(b/gcd(a,b)))

#define fios(); ios_base::sync_with_stdio(0);cin.tie(0);
#define fraction(x); cout.unsetf(ios::floatfield); cout.precision(x); cout.setf(ios::fixed,ios::floatfield);
#define file(); freopen("input.txt","r",stdin);freopen("output.txt","w",stdout);

pair<vector<int>,ll> transaction(ll m);

void buy_souvenirs(int n, long long p0){
    if(n==2){
        //subtask 1
        transaction(p0-1);
        return ;
    }
    if(n==3){
        pair<vector<int>,long long> tem=transaction(p0-1);
        vector<int> memo=tem.ff;
        if(memo.size()==1){
            long long cost=(p0-1)-tem.ss;
            transaction(cost-1);
            transaction(cost-1);
        }else{
            long long cost=(p0-1)-tem.ss;
            transaction((cost/2));
        }
        return ;
    }
    //subtask 3
    pair<vector<int>,long long> tem;
    long long o=n-1,prev=p0;
    for(long long i=1;i<n;i++){
        if((i==(n-1))&&(o!=i)){
            for(long long j=0;j<o;j++) transaction(1);
            return ;
        }
        tem=transaction(prev-1);
        long long v=prev-1;
        if((tem.ss)||(tem.ff.size()>1)) v--;
        if(tem.ff.size()>1)o--;
        for(long long j=1;j<i;j++) transaction(v);
        prev=v;
    }
    return ;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...