日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Arithmetic Sequence 三分,货仓选址,nth_element,__int128(济南)

發布時間:2025/3/19 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Arithmetic Sequence 三分,货仓选址,nth_element,__int128(济南) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.


題意 :

  • 給一序列,每次操作選擇一個數加一或者減一,需要將這個序列變成等差數列,問最小操作數

思路 :

  • 數據范圍很大又沒有頭緒,想到二分或者三分。對于不同的公差d,肯定是只有一個最優,兩邊的都比這個公差大,這就是個單谷函數(代價隨公差的變化是一個單谷函數),我們可以用三分來求這個公差。
  • 但有了公差還無法確定首項,再套一個三分會TLE
  • 設首項為x,公差為d,那么變化第一項的次數為∣x?a[1]∣|x-a[1]|x?a[1],第二項為∣x+d?a[2]∣|x+d-a[2]|x+d?a[2],|x+d*2-a[3]|,…,設t[i]=a[i]?d?(i?1)t[i]=a[i] - d*(i-1)t[i]=a[i]?d?(i?1),每一項的變化就會轉化為∣x?t[i]∣|x-t[i]|x?t[i](每一項的這個距離都共享同一個端點x,注意為什么是把它轉換成了絕對值里面的減法而不是轉換成絕對值里的加法,畢竟距離肯定有更好的性質),就轉化成了貨倉選址問題,因此,找到中位點即可
  • 需要用nth_element找中位點,sort復雜度會超(由于三分的時間復雜度要高于二分,因此求中位數禁止使用sort,請使用快速選擇算法或者部分快速排序,下面的代碼使用了北京大學提供的題解上使用的nth_element函數求解)
  • 可能會超long long,需要開128(由于數據范圍過大(1e13*2e5),在運算過程中可能會爆long long,請使用128位整數__int128)
#include <iostream> #include <algorithm>using namespace std;typedef long long ll;const int N = 2e6 + 10;int n; ll a[N], b[N];void print(__int128 x) {if (x < 0){putchar('-');x = -x;}if (x / 10)print(x / 10);putchar(x % 10 + '0'); }__int128 solve(ll d) {__int128 ans = 0;for (int i = 1; i <= n; i ++ )b[i] = a[i] - d * (i - 1);nth_element(b + 1, b + (n + 1) / 2, b + n + 1); // [1, n]中的第 (n + 1) / 2 個,下標從1開始__int128 a0 = b[(n + 1) / 2]; // 與nth_element一起使用,排序后的第這個要找的數,// 上面已經找到中位數,也就是首項a0了for (int i = 1; i <= n; i ++ ){__int128 tmp = a0 + (i - 1) * d - a[i];tmp >= 0 ? ans += tmp : ans -= tmp;}return ans; }int main() { // ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);scanf("%d", &n);for (int i = 1; i <= n; i ++ ) scanf("%lld", &a[i]);ll l = -2e13 - 5, r = 2e13 + 5;while (l < r){ll m1 = l + (r - l) / 3;ll m2 = r - (r - l) / 3;__int128 t1 = solve(m1);__int128 t2 = solve(m2);if (t1 < t2)r = m2 - 1;elsel = m1 + 1;}print(solve(l));return 0; }

總結

以上是生活随笔為你收集整理的Arithmetic Sequence 三分,货仓选址,nth_element,__int128(济南)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。