コードフォース ラウンド #FF (ディビジョン 1)-A、B、C_html/css_WEB-ITnose
A:DZY はシーケンスが大好きです
最初は間違った質問を読みました。 。悲しい。
質問はとても簡単で、方法もとても簡単です。それをDPするだけです。
dp[i][0]: 現在位置から数値を変更せずに取得した長さ。
dp[i][1]: 現在の位置に移動し、数値を変更し、長さを取得します
ただし、一度順方向に見つけてから、次に逆方向に見つける必要があります。
rrreeB: DZY は修正が大好きです水平行を選択すると、垂直行のサイズ順序は変更されませんが、各垂直行が p ずつ減少することがわかります。
したがって、x 個の水平行と y 個の垂直行を列挙して選択できます。
#include<iostream>#include<stdio.h>#include<algorithm>#include<stdlib.h>#include<string.h>using namespace std;#define maxn 110000int dp[maxn][3];int num[maxn];int a[maxn];int n;void dos(int maxx){ memset(dp,0,sizeof(dp)); memset(num,-1,sizeof(num)); for(int i=n; i>=1; i--) { if(a[i]<a[i+1]) { dp[i][0]=dp[i+1][0]+1; } else { dp[i][0]=1; } dp[i][1]=dp[i][0]; num[i]=a[i]; if(a[i]<num[i+1]) { if(dp[i][1]<dp[i+1][1]+1) { dp[i][1]=dp[i+1][1]+1; num[i]=a[i]; } } if(a[i]>=a[i+1]) { if(dp[i][1]<dp[i+1][0]+1) { dp[i][1]=dp[i+1][0]+1; num[i]=a[i+1]-1; } } } for(int i=1; i<=n; i++) { //cout<<dp[i][0]<<" "<<dp[i][1]<<" "<<num[i]<<endl; maxx=max(maxx,dp[i][0]); maxx=max(maxx,dp[i][1]); } cout<<maxx<<endl;}int main(){ while(~scanf("%d",&n)) { for(int i=1; i<=n; i++) { scanf("%d",&a[i]); } memset(dp,0,sizeof(dp)); memset(num,-1,sizeof(num)); for(int i=1; i<=n; i++) { if(a[i]>a[i-1]) { dp[i][0]=dp[i-1][0]+1; } else { dp[i][0]=1; } dp[i][1]=dp[i][0]; num[i]=a[i]; if(a[i]>num[i-1]) { if(dp[i][1]<dp[i-1][1]+1) { dp[i][1]=dp[i-1][1]+1; num[i]=a[i]; } } if(a[i]<=a[i-1]) { if(dp[i][1]<dp[i-1][0]+1) { dp[i][1]=dp[i-1][0]+1; num[i]=a[i-1]+1; } } } int maxx=-1; for(int i=1; i<=n; i++) { // cout<<dp[i][0]<<" "<<dp[i][1]<<" "<<num[i]<<endl; maxx=max(maxx,dp[i][0]); maxx=max(maxx,dp[i][1]); } dos(maxx); } return 0;}
主に次の 2 つの特性によるものです: 2 つのフィボナッチ数を加算しても 1 つのフィボナッチ数になります。
2. フィボナッチ数列の最初の 2 つの項によれば、任意の位置のフィボナッチ数と任意の長さのフィボナッチ数列の合計を O(1) 時間で取得できます。
残りは単純な区間合計の問題です。
れーい

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











公式アカウントのWebページはキャッシュを更新します。これはシンプルでシンプルで、ポットを飲むのに十分な複雑です。あなたは公式のアカウントの記事を更新するために一生懸命働きましたが、ユーザーはまだ古いバージョンを開くことができますか?この記事では、この背後にあるtwist余曲折と、この問題を優雅に解決する方法を見てみましょう。それを読んだ後、さまざまなキャッシュの問題に簡単に対処でき、ユーザーが常に新鮮なコンテンツを体験できるようになります。最初に基本について話しましょう。それを率直に言うと、アクセス速度を向上させるために、ブラウザまたはサーバーはいくつかの静的リソース(写真、CSS、JSなど)やページコンテンツを保存します。次回アクセスするときは、もう一度ダウンロードすることなく、キャッシュから直接検索できます。自然に高速です。しかし、このことは両刃の剣でもあります。新しいバージョンはオンラインです、

この記事では、CSSを使用したWebページへの効率的なPNG境界追加を示しています。 CSSはJavaScriptやライブラリと比較して優れたパフォーマンスを提供し、微妙または顕著な効果のために境界幅、スタイル、色を調整する方法を詳述していると主張しています

この記事では、ブラウザのユーザー入力を直接検証するために、必要、パターン、MIN、MAX、および長さの制限などのHTML5フォーム検証属性を使用して説明します。

記事では、HTML5クロスブラウザーの互換性を確保するためのベストプラクティスについて説明し、機能検出、プログレッシブエンハンスメント、およびテスト方法に焦点を当てています。

この記事では、HTML&lt; Datalist&GT;について説明します。オートコンプリートの提案を提供し、ユーザーエクスペリエンスの改善、エラーの削減によりフォームを強化する要素。

この記事では、html&lt; meter&gt;について説明します。要素は、範囲内でスカラーまたは分数値を表示するために使用され、Web開発におけるその一般的なアプリケーション。それは差別化&lt; Meter&gt; &lt; Progress&gt;およびex

この記事では、HTML&lt; Progress&gt;について説明します。要素、その目的、スタイリング、および&lt; meter&gt;との違い要素。主な焦点は、&lt; Progress&gt;を使用することです。タスクの完了と&lt; Meter&gt; statiの場合

この記事では、html5&lt; time&gt;について説明します。セマンティックデート/時刻表現の要素。 人間の読み取り可能なテキストとともに、マシンの読みやすさ(ISO 8601形式)のDateTime属性の重要性を強調し、Accessibilitを増やします
