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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Codeforces Round #FF

發布時間:2025/3/8 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Codeforces Round #FF 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

  A.DZY Loves Hash

  hash函數 h(x) = x % p  輸出第一次沖突的位置

#include<iostream> #include<cstdio> #include<cstdlib>using namespace std;const int maxn = 4000;int p, n; bool inhash[maxn];int main() {freopen("447A.in", "r", stdin);cin >> p >> n;for(int i = 0; i < n; i++) {long long t;cin >> t;if(!inhash[t % p]) inhash[t % p] = 1;else {cout << i+1 << endl;return 0;}}cout << -1 << endl;return 0; }

  

  B.DZY Loves Strings

    對于一個字符串,每個字母有相應的權值,由這個公式計算f(s)

?

現在能夠插入k個任意字母,要求使得新的字符串f(s')值最大

  字符串就是幌子,替換成數字,插入的字符很明顯貪心一下取最大的,一開始也沒發現規律,瞎搞的,題解的意思大概是:

  插入x到位置p之后,則增加的權值為x*p+Ws(p+1)+Ws(p+2)...(p以后每一個權值) -> x+x+x+x...+Ws(p+1)+Ws(p+2)...容易觀察到其實是用x替換前p個Ws,而由于貪心策略,x >= Ws.所以上式要取最大,p應該取|s|,對于剩下k-1個x同理,最終轉化為把p個x插入到最后端得到的f(s‘)

(這份代碼沒刪除之前亂搞的部分,比較亂就不貼了)

(B都寫不來。。。這絕壁回家養豬節奏!)

?

  C.DZY Loves Sequences

  咋一眼看像是dp,可是自己死活想不出來思路,O(N),結果是自己沒自習審題,ai, ai+1, ai+2 連續的!

  大意是給你一個數列,最多修改一個數字,球得最長的單調遞增子串(嚴格的)(連續的!!!)

  可以設想一下如果x是要修改的數字,a[x+1]-a[x-1]>1(因為是整數,嚴格單調),以x為界左邊是一個以a[x-1]為尾的單調增,右邊是a[x+1]為首單調增,我們可以預處理出這兩邊的長度,然后枚舉每一個a[i](2~n-1),取max即可

  預處理過程就算是簡單dp吧...以從左往右為例 f[i] = 1 (a[i] <= a[i-1])  或 f[i-1]+1 (a[i] > a[i-1]) 

?

(審題吶!英文不好容易漏細節...)

  

#include <iostream> #include <cstdlib> #include <cstdio>using namespace std;const int maxn = 100000+50;int n; int a[maxn], r[maxn], l[maxn], f[maxn];int main() {scanf("%d", &n);for(int i = 1; i <= n; i++)scanf("%d", a+i);for(int i = 1; i <= n; i++)f[i] = 1;l[1] = 1;for(int i = 2; i <= n; i++)l[i] = (a[i] > a[i-1]? l[i-1]+1: 1);r[n] = 1;for(int i = n-1; i >= 1; i--)r[i] = (a[i] < a[i+1]? r[i+1]+1: 1);for(int i = 1; i <= n; i++) {if(i >= 2) f[i] = max(f[i], 1+l[i-1]);if(i <= n-1) f[i] = max(f[i], 1+r[i+1]);if(a[i+1] - a[i-1] > 1) f[i] = max(f[i], 1+r[i+1]+l[i-1]);}int ans = 0;for(int i = 1; i <= n; i++)ans = max(ans, f[i]);printf("%d\n", ans); return 0; }

?

  

轉載于:https://www.cnblogs.com/gemmeg/p/3854371.html

總結

以上是生活随笔為你收集整理的Codeforces Round #FF的全部內容,希望文章能夠幫你解決所遇到的問題。

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