{Целевой язык не указан, приведу пример на Haskell}
Цена вычисляется как
C - максимальная цена, которую мы можем себе позволить.
Поэтому , где div - оператор целочисленного деления.
Она не могла бы набрать целое количество очков не входящее в промежуток [36;52], а также любое нецелое количество очков.
Объяснение:
Минимальное число очков которое она может набрать, если промахнется в двух последних бросках, т.к. именно за них она получает больше всего очков. Т.е. минимально число очков вычисляется как 1+2+3+4+5+6+7+8 = 36.
Минимальное число очков которое она может набрать, если промахнется в двух первых бросках, т.к. именно за них она получает меньше всего очков. Т.е. максимально число очков вычисляется как 3+4+5+6+7+8+9+10 = 52.
Между 36 и 52 она может набрать любое целое число очков.
"Сместим" проигрыш с 9 позиции на 8. Получим 1+2+3+4+5+6+7+0+9+0 = 37.
Затем с 8 на 7: 1+2+3+4+5+6+0+8+9+0 = 38.
И т.д. вплоть до 0+0+3+4+5+6+7+8+9+10=52
Получается что она может набрать любое целое число очков в промежутке [36;52]
Не забывайте нажать " ", поставить оценку и, если ответ удовлетворил, то выберите его как "Лучший"
Успехов в учебе
#include <iostream>
#include <vector>
#include <cstdint>
using namespace std; template <class T>
istream& operator>>(istream &in, vector<T> &vec) { for (auto &it : vec) in >> it; return in;
}
template <class T>
ostream& operator<<(ostream &out, vector<T> &vec) { for (auto &it : vec) out << it << ' '; return out;
}
template <class T, class U>
istream& operator>>(istream &in, pair<T, U> &pair) { in >> pair.first >> pair.second; return in;
}
template <class T, class U>
ostream& operator<<(ostream &out, pair<T, U> &pair) { out << pair.first << ' ' << pair.second; return out;
}
signed main(void) { int32_t n; cin >> n; vector<vector<int64_t>> a(n, vector<int64_t>(n,-1)); int64_t x = 0, y = n/2; a[x][y] = 1; for(int32_t i = 2; i <= n*n; ++i) { int _x = x, _y = y; if(!x) { x = n-1; } else { --x; } if(y == n-1) { y = 0; } else { ++y; } if(a[x][y] != -1) { x= _x, y = _y; while(a[x][y] != -1) { if(x == n-1) { x = 0; } else { ++x; } } } a[x][y] = i; } for(int32_t i = 0; i < n; ++i) { cout << a[i] << '\n'; } return 0; }
Объяснение:
Запишем на C++ то, что написано в условии.
Если надо, то код также прикрепил в виде файла
Списывать не хорошо)
Если повезёт увидемся в (СИРИУС)