Advertisement
Raslboyy

113762

Jan 29th, 2020
144
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.83 KB | None | 0 0
  1. #include <iostream>
  2. #include <vector>
  3. #include <algorithm>
  4. #include <string>
  5. #include <math.h>
  6. #include <climits>
  7.  
  8. //#pragma GCC optimize("O3, unroll-loops");
  9.  
  10. #include <list>
  11. #include <map>
  12. #include <set>
  13. #include <queue>
  14. #include <unordered_map>
  15. #include <unordered_set>
  16.  
  17. //#include <chrono>
  18. //#include <fstream>
  19. //#include <bits/stdc++.h>
  20.  
  21. #define mp make_pair
  22. #define pb push_back
  23. #define eb emplace_back
  24. #define x first
  25. #define y second
  26. #define sz(x) (int)x.size()
  27. #define all(x) begin(x), end(x)
  28. #define rall(x) rbegin(x), rend(x)
  29. #define FOR(i,a,b) for (int i = (a); i < (b); i++)
  30. #define RFOR(i,b,a) for (int i = (b) - 1; i >= (a); i--)
  31.  
  32. using namespace std;
  33.  
  34. typedef unsigned long long ull;
  35. typedef long long ll;
  36. typedef long double ld;
  37. typedef pair<int, int> pi;
  38. typedef pair<ll, ll> pl;
  39. typedef vector<int> veci;
  40. typedef vector<bool> vecb;
  41. typedef vector<vector<int>> vvi;
  42. typedef vector<vector<bool>> vvb;
  43.  
  44. const int INF_I = 1e9;
  45. const ll INF_LL = 1e18;
  46.  
  47. int main() {
  48.     /*ifstream cin("in.txt");
  49.     ofstream cout("out.txt");
  50.     auto start_time = chrono::high_resolution_clock::now();*/
  51.  
  52.     ios::sync_with_stdio(false);
  53.     cin.tie(0);
  54.     cout.tie(0);
  55.  
  56.  
  57.     ll s, k;
  58.     cin >> k >> s;
  59.     ll sq = sqrt(ld(s)) + 1;
  60.     ll l = 0;
  61.     for (ll n_i = 0; ; n_i++) {
  62.         for (; ((k + 1) + (k + l - n_i)) * (ld)(l - n_i) / 2 <= s; l++);
  63.         /*while (l + 1 < r) {
  64.             ll m = (l + r) / 2;
  65.             if ()
  66.                 l = m;
  67.             else
  68.                 r = m;
  69.         }*/
  70.         l = max(0LL, l - 1);
  71.         if (((k + 1) + (k + l - n_i)) * (ld)(l - n_i) / 2 <= s  &&
  72.             s <= ((k + n_i + 1) + (k + l)) * (ld)(l - n_i) / 2) {
  73.             cout << n_i + k << endl;
  74.             return 0;
  75.         }
  76.     }
  77.  
  78.  
  79.     /*auto end_time = chrono::high_resolution_clock::now();
  80.     chrono::duration<double> duration = end_time - start_time;
  81.     cout << duration.count() << "\n";
  82.     cin.close();
  83.     cout.close();*/
  84.     return 0;
  85. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement