1375d 1900的題
題意:給你乙個n,然後是乙個陣列,其中的值為0~n,定義mex為陣列中0~n不存在的最小的那個,操作為可以將第i個數字為mex,使得這個陣列為不遞減的陣列,可以證明操作次數在2n次內一定能實現,問你操作次數是多少,並輸出相對應的索引,操作次數不要求是最優的。
思路:看到在2n次內一定能實現,並且不要求是最優的,可以想到我們一定可以把這個陣列變為乙個我們想變成的陣列,例如1~n的遞增,或者說是0~n-1的遞增,通過模擬可以知道這兩種情況在特定的條件下都是能夠實現的。
首先當mex=n時,可以將a【n-1】=mex,同時n–。
當mex!=n是,a【mex】=mex。
可以知道這種操作在2*n次內一定能夠實現。
**如下
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using
namespace std;
typedef
long
long ll;
typedef
unsigned
long
long ull;
typedef pair<
int,
int> pii;
#define rep(i, a, n) for(int i = a; i <= n; i++)
#define per(i, a, n) for(int i = n; i >= a; i--)
#define ios std::ios::sync_with_stdio(false), cin.tie(0), cout.tie(0);
#define fopen freopen("file.in","r",stdin);freopen("file.out","w",stdout);
#define fclose fclose(stdin);fclose(stdout);
#define pi 3.14159265358979323846
const
int inf =
1e9;
const ll onf =
1e18
;const
int maxn =
1e5+10;
inline
intread()
while
(ch>=
'0'&&ch<=
'9')
return x*f;
}int a[
1010];
int vis[
1010
], n;
intsolve()
inline
voidcf(
)else
}int op = v.
size()
;printf
("%d\n"
, op)
;rep
(i,0
,op-1)
printf
("%d "
, v[i]+1
);printf
("\n");
}return;}
signed
main()
Codeforces 703D 樹狀陣列
codeforces 703d 題意 給1e6長度的區間,每個單位代表乙個數。給1e6個詢問,每次問區間內出現次數為偶數次的數異或和。思路 賽中的時候想莫隊水過去,結果pretest都沒過233 正解是樹狀陣列。首先假設是奇數次的話,就是乙個簡單字首和。現在偶數次,有乙個處理技巧就是記錄這個區間出現...
codeforces 912D 期望計算
題目鏈結 題意 在乙個n m的魚塘裡面放置k條魚,每次可以選定乙個r r的矩陣並獲得矩陣內魚的數量的分數。請問該如何在魚塘裡面放置魚,使得最後的期望得分最大。思路 直接通過列舉放置魚的位置計算期望得分明顯非常非常不現實,於是我們換一種計算思路我們去計算各點放置魚之後可以得到的期望得分,然後取前k大的...
codeforces 523D 優先佇列
題意 給你n個任務單和k個機器,每個任務單有兩個變數開始的時間,完成所需要的時間,問你最優去做的話,每個訂單的結束時間是?題解 題目保證了資料是遞增排序的,那麼我們就不用sort了,直接做。然後這裡有個小套路 因為題目可以有k個機器,那我們可以先用k個0進去乙個優先佇列以達到模擬k個優先佇列的作用,...