| Task: | Tikut | 
| Sender: | Pikaksi | 
| Submission time: | 2024-11-04 20:59:43 +0200 | 
| Language: | C++ (C++20) | 
| Status: | READY | 
| Result: | 15 | 
| group | verdict | score | 
|---|---|---|
| #1 | ACCEPTED | 7 | 
| #2 | ACCEPTED | 8 | 
| #3 | WRONG ANSWER | 0 | 
| #4 | WRONG ANSWER | 0 | 
| #5 | WRONG ANSWER | 0 | 
| #6 | WRONG ANSWER | 0 | 
| test | verdict | time | group | |
|---|---|---|---|---|
| #1 | ACCEPTED | 0.00 s | 1, 3, 4, 5, 6 | details | 
| #2 | ACCEPTED | 0.00 s | 1, 4, 5, 6 | details | 
| #3 | ACCEPTED | 0.00 s | 1, 4, 5, 6 | details | 
| #4 | ACCEPTED | 0.00 s | 1, 4, 5, 6 | details | 
| #5 | ACCEPTED | 0.00 s | 2, 5, 6 | details | 
| #6 | ACCEPTED | 0.01 s | 2, 5, 6 | details | 
| #7 | ACCEPTED | 0.00 s | 3, 5, 6 | details | 
| #8 | ACCEPTED | 0.00 s | 3, 5, 6 | details | 
| #9 | ACCEPTED | 0.00 s | 3, 5, 6 | details | 
| #10 | ACCEPTED | 0.00 s | 3, 5, 6 | details | 
| #11 | WRONG ANSWER | 0.00 s | 3, 5, 6 | details | 
| #12 | ACCEPTED | 0.00 s | 4, 5, 6 | details | 
| #13 | WRONG ANSWER | 0.00 s | 4, 5, 6 | details | 
| #14 | WRONG ANSWER | 0.00 s | 4, 5, 6 | details | 
| #15 | WRONG ANSWER | 0.00 s | 4, 5, 6 | details | 
| #16 | ACCEPTED | 0.01 s | 5, 6 | details | 
| #17 | WRONG ANSWER | 0.01 s | 5, 6 | details | 
| #18 | WRONG ANSWER | 0.01 s | 5, 6 | details | 
| #19 | WRONG ANSWER | 0.01 s | 5, 6 | details | 
| #20 | WRONG ANSWER | 0.17 s | 6 | details | 
| #21 | WRONG ANSWER | 0.10 s | 6 | details | 
| #22 | WRONG ANSWER | 0.17 s | 6 | details | 
Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
struct Frac2
{
    int number;
    int divisor;
    double result;
 
    void update()
    {
        result = (double)number / (double)(divisor + 1);
    }
 
    Frac2(int _number, int _divisor)
    {
        number = _number;
        divisor = _divisor;
        update();
    }
 
    bool operator<(Frac2 frac) const
    {
        return result < frac.result;
    }
};
 
multiset<Frac2> numbersSorted2;
 
void printSet2()
{
    cout << "printing set:\n";
    for (Frac2 frac : numbersSorted2) {
        cout << frac.number << " " << frac.divisor << " " << frac.result << "\n";
    }
}
 
void getWorkingDifference(vector<int>& results)
{
    Frac2 fracSmall = *numbersSorted2.begin();
    int smallestNumber = fracSmall.number / fracSmall.divisor;
 
    Frac2 fracBig = *numbersSorted2.rbegin();
    int biggestNumber = fracBig.number / fracBig.divisor;
    if (fracBig.number % fracBig.divisor != 0) {
        biggestNumber += 1;
    }
    results.push_back(biggestNumber - smallestNumber);
    cout << results.back() << " ";
}
 
void runWorkingProgram(int n, int m, vector<int>& testNumbers, vector<int>& results)
{
    cout << "STARTINGWORKINGPROGRAM\n";
    for (int i = 0; i < n; i++) {
        int number;
        //cin >> number;
        number = testNumbers[i];
        numbersSorted2.emplace(number, 1);
    }
 
    for (int k = 0; k < m; k++) {
        printSet2();
 
        Frac2 frac = *numbersSorted2.rbegin();
        Frac2 newFrac = Frac2(frac.number, frac.divisor + 1);
        
        numbersSorted2.erase(--numbersSorted2.end());
        //cout << "size = " << numbersSorted.size() << "\n";
        numbersSorted2.insert(newFrac);
        //cout << "size = " << numbersSorted.size() << "\n";
 
        getWorkingDifference(results);
    }
    //printSet();
    cout << "ENDINGWORKINGPROGRAM\n";
}
struct Frac
{
    int number;
    int divisor;
    int resultBigger;
    Frac(int _number, int _divisor)
    {
        number = _number;
        divisor = _divisor;
        
        resultBigger = _number / _divisor;
        if (_number % _divisor != 0) {
            resultBigger += 1;
        }
    }
    bool operator<(Frac frac) const
    {
        if (resultBigger == frac.resultBigger) {
            //cout << "first = " << (number / (divisor + 1)) << "\n";
            //cout << "second = " << (frac.number / (frac.divisor + 1)) << "\n";
            return (number / (divisor + 1)) < (frac.number / (frac.divisor + 1));
        }
        return resultBigger < frac.resultBigger;
    }
};
multiset<Frac> numbersSorted;
int minNumber = INT_MAX;
void printSet()
{
    cout << "printing set:\n";
    for (Frac frac : numbersSorted) {
        cout << frac.number << " " << frac.divisor << " " << frac.resultBigger << "\n";
    }
}
int getWorkingDifference()
{
    Frac fracBig = *numbersSorted.rbegin();
    int biggestNumber = fracBig.number / fracBig.divisor;
    if (fracBig.number % fracBig.divisor != 0) {
        biggestNumber += 1;
    }
    return biggestNumber - minNumber;
}
void shuffle(int& n, int& m, vector<int>& testNumbers)
{
    minNumber = INT_MAX;
    n = (rand() % 5) + 1;
    
    int sum = 0;
    numbersSorted2.clear();
    numbersSorted.clear();
    testNumbers.clear();
    for (int i = 0; i < n; i++) {
        int random = (rand() % 10) + 1;
        testNumbers.push_back(random);
        sum += random;
    }
    sum -= n;
    m = min((rand() % 10) + 1, sum);
}
int main()
{
    int n, m;
    cin >> n >> m;
    //n = 3; m = 9; vector<int> testNumbers = {3, 4, 5};
    //n = 2; m = 6; vector<int> testNumbers = {2, 6};
    //m = 9; vector<int> testNumbers = {1000, 999, 999, 500, 500, 100}; n = testNumbers.size();
    //m = 10; vector<int> testNumbers = {3, 5, 5, 9, 9}; n = testNumbers.size();
    //m = 10; vector<int> testNumbers = {10, 11}; n = testNumbers.size();
    //for (int test = 0; test < 1; test++) {
        //shuffle(n, m, testNumbers);
        //vector<int> resultsWorking;
        //runWorkingProgram(n, m, testNumbers, resultsWorking);
        for (int i = 0; i < n; i++) {
            int number;
            cin >> number;
            //number = testNumbers[i];
            minNumber = min(minNumber, number);
            numbersSorted.emplace(number, 1);
        }
        //cout << "min number = " << minNumber << "\n";
        //if (test == 1)
            //printSet();
        for (int k = 0; k < m; k++) {
            //cout << "k=" << k << "\n";
            //if (test == 1)
                //printSet();
            Frac frac = *numbersSorted.rbegin();
            Frac newFrac = Frac(frac.number, frac.divisor + 1);
            
            numbersSorted.erase(--numbersSorted.end());
            //cout << "size = " << numbersSorted.size() << "\n";
            numbersSorted.insert(newFrac);
            minNumber = min(minNumber, newFrac.number / newFrac.divisor);
            //cout << "size = " << numbersSorted.size() << "\n";
            int ans = getWorkingDifference();
            cout << ans;
            if (k != m - 1) {
                cout << " ";
            }
        }
        //cout << "end";
        //if (test == 1)
            //printSet();
    //}
}Test details
Test 1
Group: 1, 3, 4, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 1 1 6  | 
| correct output | 
|---|
| 0 | 
| user output | 
|---|
| 0 | 
Test 2
Group: 1, 4, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 5 10 4 8 6 2 7  | 
| correct output | 
|---|
| 5 4 2 2 2 1 1 1 1 1 | 
| user output | 
|---|
| 5 4 2 2 2 1 1 1 1 1 | 
Test 3
Group: 1, 4, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 5 10 5 5 8 6 7  | 
| correct output | 
|---|
| 3 3 2 3 2 2 1 1 1 2 | 
| user output | 
|---|
| 3 3 2 3 2 2 1 1 1 2 | 
Test 4
Group: 1, 4, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 5 10 8 7 9 6 10  | 
| correct output | 
|---|
| 4 4 3 3 2 2 1 2 2 1 | 
| user output | 
|---|
| 4 4 3 3 2 2 1 2 2 1 | 
Test 5
Group: 2, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 1000 1071 3 2 3 1 3 3 2 3 2 3 2 2 2 1 2 ...  | 
| correct output | 
|---|
| 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 ... | 
| user output | 
|---|
| 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 ... | 
Test 6
Group: 2, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 1000 1500 3 2 2 3 2 3 2 2 2 3 2 2 3 3 3 ...  | 
| correct output | 
|---|
| 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 ... | 
| user output | 
|---|
| 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 ... | 
Test 7
Group: 3, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 1000 2 15 710 210 347 398 66 318 277 ...  | 
| correct output | 
|---|
| 994 994 | 
| user output | 
|---|
| 994 994 | 
Test 8
Group: 3, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 1000 2 743 890 592 942 736 969 616 50...  | 
| correct output | 
|---|
| 498 496 | 
| user output | 
|---|
| 498 496 | 
Test 9
Group: 3, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 1000 2 987 968 920 994 988 918 914 95...  | 
| correct output | 
|---|
| 500 500 | 
| user output | 
|---|
| 500 500 | 
Test 10
Group: 3, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 1000 2 996 1000 998 998 999 997 997 9...  | 
| correct output | 
|---|
| 500 500 | 
| user output | 
|---|
| 500 500 | 
Test 11
Group: 3, 5, 6
Verdict: WRONG ANSWER
| input | 
|---|
| 1000 2 501 501 501 501 501 501 501 50...  | 
| correct output | 
|---|
| 1 168 | 
| user output | 
|---|
| 1 251 | 
Test 12
Group: 4, 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 100 200 145 136 74 83 73 36 196 115 11...  | 
| correct output | 
|---|
| 194 190 189 183 182 181 181 17... | 
| user output | 
|---|
| 194 190 189 183 182 181 181 17... | 
Test 13
Group: 4, 5, 6
Verdict: WRONG ANSWER
| input | 
|---|
| 100 200 157 110 168 155 192 107 146 15...  | 
| correct output | 
|---|
| 95 96 96 95 93 94 94 94 90 91 ... | 
| user output | 
|---|
| 95 96 96 95 93 94 94 94 90 91 ... | 
Test 14
Group: 4, 5, 6
Verdict: WRONG ANSWER
| input | 
|---|
| 50 200 137 118 160 118 146 160 140 18...  | 
| correct output | 
|---|
| 98 98 98 96 90 91 88 88 84 86 ... | 
| user output | 
|---|
| 98 98 98 96 90 91 88 88 84 86 ... | 
Test 15
Group: 4, 5, 6
Verdict: WRONG ANSWER
| input | 
|---|
| 100 200 147 174 186 148 155 128 158 18...  | 
| correct output | 
|---|
| 99 99 98 98 97 97 96 96 95 95 ... | 
| user output | 
|---|
| 99 99 98 98 97 97 96 96 95 95 ... | 
Test 16
Group: 5, 6
Verdict: ACCEPTED
| input | 
|---|
| 1000 2000 928772177 816188227 216592201 ...  | 
| correct output | 
|---|
| 991676844 990940224 990685481 ... | 
| user output | 
|---|
| 991676844 990940224 990685481 ... | 
Test 17
Group: 5, 6
Verdict: WRONG ANSWER
| input | 
|---|
| 1000 2000 665759876 597950008 615453266 ...  | 
| correct output | 
|---|
| 498801198 498681904 498504321 ... | 
| user output | 
|---|
| 498801198 498681904 498504321 ... | 
Test 18
Group: 5, 6
Verdict: WRONG ANSWER
| input | 
|---|
| 500 2000 683288817 784230412 626685186 ...  | 
| correct output | 
|---|
| 497667621 498434895 495465990 ... | 
| user output | 
|---|
| 497667621 498434895 495465990 ... | 
Test 19
Group: 5, 6
Verdict: WRONG ANSWER
| input | 
|---|
| 1000 2000 666667000 809309500 571572000 ...  | 
| correct output | 
|---|
| 499499500 499249250 498999000 ... | 
| user output | 
|---|
| 499499500 499249250 498999000 ... | 
Test 20
Group: 6
Verdict: WRONG ANSWER
| input | 
|---|
| 100000 200000 861772559 734298084 983382252 ...  | 
| correct output | 
|---|
| 499973914 499985299 499985141 ... | 
| user output | 
|---|
| 499973914 499985299 499985141 ... | 
Test 21
Group: 6
Verdict: WRONG ANSWER
| input | 
|---|
| 30000 200000 691834579 617419813 514778075 ...  | 
| correct output | 
|---|
| 499967533 499976270 499969810 ... | 
| user output | 
|---|
| 499967533 499976270 499969810 ... | 
Test 22
Group: 6
Verdict: WRONG ANSWER
| input | 
|---|
| 100000 200000 820255000 960780000 741965000 ...  | 
| correct output | 
|---|
| 499995000 499992500 499990000 ... | 
| user output | 
|---|
| 499995000 499992500 499990000 ... | 
