Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include <cstdio>
- #include <iostream>
- #include <algorithm>
- #include <vector>
- #include <string>
- #include <string.h>
- #include <queue>
- #include <map>
- #include <set>
- #include <cmath>
- #include <sstream>
- #include <stack>
- #include <cassert>
- #define pb push_back
- #define mp make_pair
- #define PI 3.1415926535897932384626433832795
- #define sqr(x) (x)*(x)
- #define forn(i, n) for(int i = 0; i < n; ++i)
- #define ALL(x) x.begin(), x.end()
- #define F first
- #define S second
- #define m0(x) memset(x,0,sizeof(x))
- #define m1(x) memset(x,-1,sizeof(x))
- #define CC(x) cout << (x) << "\n"
- #define pw(x) (1ull<<(x))
- using namespace std;
- typedef long long ll;
- typedef unsigned long long ull;
- typedef long double ld;
- typedef pair<int,int> pii;
- const int INF = 2147483647;
- const ll LLINF = 9223372036854775807LL;
- ll t[100500];
- ll n,m;
- bool check(ll ti) {
- ll can = 0;
- for (int i=0;i<n;i++) {
- can+=(ti/t[i]);
- if (can>=m) return true;
- }
- return false;
- }
- int main() {
- //freopen("input.txt", "r", stdin);
- //freopen("output.txt", "w", stdout);
- cin >> n >> m;
- for (int i=0;i<n;i++) scanf("%lld", &t[i]);
- ll l=0, r=ll(2*1e18);
- while (r-l>1) {
- ll mid = (l+r)/2;
- if (check(mid)) r=mid; else l=mid;
- }
- cout << r << "\n";
- return 0;
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement