#include #include #include #include using namespace std; int main() { int n, K; cin >> n >> K; vector a(n); for (int i = 0; i < n; i++) { scanf("%d", &a[i]); } long long d = 0; vector b(n); for (int i = 0; i < n; i++) { scanf("%d", &b[i]); d += abs(b[i] - a[i]); } long long ans = 0; while (K--) { ans += d; // next_permutation // 正当性は明らかなので、計算量解析だけおこなう。 // // 解析にはポテンシャルを用いる。 // ポテンシャル関数は "Φ:=a[i]>a[i+1] となる i の総数"と定義する。 // // #1の while が回った回数を X とする。 // このとき、⊿Φ=1-Xである。なぜなら、 // #2のswapによりΦは+1、 // #3のreverseによりΦは-Xするからである。 // // ならしコストは、(whileが回った回数)+(ポテンシャルの変化量)とみなせるので、 // ならしコストは X+(1-X)=1 となる。 // #1 int i = n - 2; while (i >= 0 && a[i] >= a[i + 1]) i--; if (i == -1) { reverse(a.begin(), a.end()); d = 0; for (int i = 0; i < n; i++) { d += abs(b[i] - a[i]); } continue; } int j = i + 1; while (j + 1 < n && a[j + 1] > a[i]) j++; for (int k = i; k < n; k++) { d -= abs(b[k] - a[k]); } // #2 swap(a[i], a[j]); // #3 reverse(a.begin() + i + 1, a.end()); for (int k = i; k < n; k++) { d += abs(b[k] - a[k]); } } cout << ans << endl; }