第三十次codeforces竞技结束 #296 Div 2
Problems # Name A Playing with Paper standard input/output 2 s, 256 MB x2429 B Error Correct System standard input/output 2 s, 256 MB x953 C Glass Carving standard input/output 2 s, 256 MB x584 第三十次……好想到紫啊好想紫55555,两个1A,14
Problems
# | Name | ||
---|---|---|---|
A |
Playing with Paper
standard input/output 2 s, 256 MB |
![]() ![]() |
![]() |
B |
Error Correct System
standard input/output 2 s, 256 MB |
![]() ![]() |
![]() |
C |
Glass Carving
standard input/output 2 s, 256 MB |
![]() ![]() |
![]() |
第三十次……好想到紫啊好想紫55555,两个1A,14min,然后我看Standing的时候你们造么! 28名啊!!!
然后被C骗住了,我以为是zkw线段树……居然是考察数据结构set的问题……
然后……Failed System Test…… 原因?
A. Playing with Paper
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output
One day Vasya was sitting on a not so interesting Maths lesson and making an origami from a rectangular a mm ?×? bmm sheet of paper (a?>?b). Usually the first step in making an origami is making a square piece of paper from the rectangular sheet by folding the sheet along the bisector of the right angle, and cutting the excess part.

After making a paper ship from the square piece, Vasya looked on the remaining (a?-?b) mm ?×? b mm strip of paper. He got the idea to use this strip of paper in the same way to make an origami, and then use the remainder (if it exists) and so on. At the moment when he is left with a square piece of paper, he will make the last ship from it and stop.
Can you determine how many ships Vasya will make during the lesson?
Input
The first line of the input contains two integers a, b (1?≤?b?a?≤?1012) — the sizes of the original sheet of paper.
Output
Print a single integer — the number of ships that Vasya will make.
Sample test(s)
input
2 1
output
2
input
10 7
output
6
input
1000000000000 1
output
1000000000000
Note
Pictures to the first and second sample test.

说一张长方形的纸~,每次都以较短边为边长裁一个正方形下来折个纸船,问长宽已知的长方形纸能折多少个纸船。
我想说……做题的时候有这个图么!!!
每次如果裁剪的效果没有达到a的剩余部分
其实看到这个图大家应该就立马懂了,每次不要一裁裁一个正方形,咱们要裁一串,就是 a/b 个。
Code:
#include <cmath> #include <cctype> #include <cstdio> #include <string> #include <cstdlib> #include <cstring> #include <iostream> #include <algorithm> using namespace std; #define Max(a,b) ((a)>(b)?(a):(b)) #define Min(a,b) ((a) b; } int main() { long long a=0,b=0,c=0,t=0; cin>>a>>b; while(a!=b) { if(a%b) { c+=(a/b); a=a%b; t=a; a=b; b=t; } else { c+=(a/b); a=b; } } cout<br> <p> </p> <p> </p> <p> </p> <p> </p> <p> </p> <p> </p> <h2 id="B-Error-Correct-System">B. Error Correct System</h2> <p> </p> <p> time limit per test</p> 2 seconds <p> </p> <p> memory limit per test</p> 256 megabytes <p> </p> <p> input</p> standard input <p> </p> <p> output</p> standard output <p> </p> <p> Ford Prefect got a job as a web developer for a small company that makes towels. His current work task is to create a search engine for the website of the company. During the development process, he needs to write a subroutine for comparing strings <span><em>S</em></span> and <span><em>T</em></span> of equal length to be "similar". After a brief search on the Internet, he learned about the<span>Hamming distance</span> between two strings <span><em>S</em></span> and <span><em>T</em></span> of the same length, which is defined as the number of positions in which <span><em>S</em></span> and <span><em>T</em></span> have different characters. For example, the Hamming distance between words "<span>permanent</span>" and "<span>pergament</span>" is two, as these words differ in the fourth and sixth letters.</p> <p> Moreover, as he was searching for information, he also noticed that modern search engines have powerful mechanisms to correct errors in the request to improve the quality of search. Ford doesn't know much about human beings, so he assumed that the most common mistake in a request is swapping two arbitrary letters of the string (not necessarily adjacent). Now he wants to write a function that determines which two letters should be swapped in string<span><em>S</em></span>, so that the Hamming distance between a new string <span><em>S</em></span> and string <span><em>T</em></span> would be as small as possible, or otherwise, determine that such a replacement cannot reduce the distance between the strings.</p> <p> Help him do this!</p> <p> </p> <p> Input</p> <p> The first line contains integer <span><em>n</em></span> (<span>1?≤?<em>n</em>?≤?200?000</span>) — the length of strings <span><em>S</em></span> and <span><em>T</em></span>.</p> <p> The second line contains string <span><em>S</em></span>.</p> <p> The third line contains string <span><em>T</em></span>.</p> <p> Each of the lines only contains <span>lowercase</span> Latin letters.</p> <p> </p> <p> Output</p> <p> In the first line, print number <span><em>x</em></span> — the minimum possible Hamming distance between strings <span><em>S</em></span> and <span><em>T</em></span> if you swap at most one pair of letters in <span><em>S</em></span>.</p> <p> In the second line, either print the indexes <span><em>i</em></span> and <span><em>j</em></span> (<span>1?≤?<em>i</em>,?<em>j</em>?≤?<em>n</em></span>, <span><em>i</em>?≠?<em>j</em></span>), if reaching the minimum possible distance is possible by swapping letters on positions <span><em>i</em></span> and <span><em>j</em></span>, or print "<span>-1 -1</span>", if it is not necessary to swap characters.</p> <p> If there are multiple possible answers, print any of them.</p> <p> </p> <p> Sample test(s)</p> <p> </p> <p> </p> <p> input</p> <pre class="brush:php;toolbar:false">9 pergament permanent
output
1 4 6
input
6 wookie cookie
output
1 -1 -1
input
4 petr egor
output
2 1 2
input
6 double bundle
output
2 4 1
Note
In the second test it is acceptable to print i?=?2, j?=?3.
题目问,如果最多允许把s中的两个不同位置的字符调换位置,那么调换后(也可以不调换)海明距离最小是多少。
假设原先海明距离是k,不调换肯定依然是k,调换的话如果要比k小只有2种情况:
1)[s]A [t]B 和某处的[s]B [t]A 调换位置,那么有两个不同处被解决了,即海明距离小了2个,最小为k-2.
2)[s]A [t]B 和某处的[s]B [t]C 调换位置,或
[s]A [t]B 和某处的[s]C [t]A 调换位置, 那么有一个不同处被解决了,即海明距离小了2个,最小为k-1.
那么,该怎么写呢?
由于字符的不同处可多可少,感觉如果全都消耗时间空间比较浪费所以我使用的是map,有的就放进来,读的过程中还可以同时把海明距离数出来,这是O(n)。
用map找由于其本质是红黑树,所以是在O(lgn)的时间内寻找到,综合来看最坏情况也是nlgn,可行。
Code:
#include <map> #include <cmath> #include <cctype> #include <cstdio> #include <string> #include <cstdlib> #include <cstring> #include <iostream> #include <algorithm> using namespace std; typedef pair<char> pcc; #define Max(a,b) ((a)>(b)?(a):(b)) #define Min(a,b) ((a) b; } map <pcc> mpi; map <char> mci,mcii; int main() { int flag=0,x=-1,y=-1; int n=0,cnt=0; cin>>n; string s,t; cin>>s>>t; mpi.clear(); mci.clear(); mcii.clear(); for(int i=0;i<n if cnt mpi flag="2,x=mpi[make_pair(t[i],s[i])],y=i+1;" mci forget a half god... mcii cout return><br> <br> <p> </p> <h2 id="C-Glass-Carving">C. Glass Carving</h2> <p> </p> <p> time limit per test</p> 2 seconds <p> </p> <p> memory limit per test</p> 256 megabytes <p> </p> <p> input</p> standard input <p> </p> <p> output</p> standard output <p> </p> <p> Leonid wants to become a glass carver (the person who creates beautiful artworks by cutting the glass). He already has a rectangular <span><em>w</em></span> mm <span>?×?</span> <span><em>h</em></span> mm sheet of glass, a diamond glass cutter and lots of enthusiasm. What he lacks is understanding of what to carve and how.</p> <p> In order not to waste time, he decided to practice the technique of carving. To do this, he makes vertical and horizontal cuts through the entire sheet. This process results in making smaller rectangular fragments of glass. Leonid does not move the newly made glass fragments. In particular, a cut divides each fragment of glass that it goes through into smaller fragments.</p> <p> After each cut Leonid tries to determine what area the largest of the currently available glass fragments has. Since there appear more and more fragments, this question takes him more and more time and distracts him from the fascinating process.</p> <p> Leonid offers to divide the labor — he will cut glass, and you will calculate the area of the maximum fragment after each cut. Do you agree?</p> <p> </p> <p> Input</p> <p> The first line contains three integers <span><em>w</em>,?<em>h</em>,?<em>n</em></span> (<span>2?≤?<em>w</em>,?<em>h</em>?≤?200?000</span>, <span>1?≤?<em>n</em>?≤?200?000</span>).</p> <p> Next <span><em>n</em></span> lines contain the descriptions of the cuts. Each description has the form <span><em>H y</em></span> or <span><em>V x</em></span>. In the first case Leonid makes the horizontal cut at the distance <span><em>y</em></span> millimeters (<span>1?≤?<em>y</em>?≤?<em>h</em>?-?1</span>) from the lower edge of the original sheet of glass. In the second case Leonid makes a vertical cut at distance <span><em>x</em></span> (<span>1?≤?<em>x</em>?≤?<em>w</em>?-?1</span>) millimeters from the left edge of the original sheet of glass. It is guaranteed that Leonid won't make two identical cuts.</p> <p> </p> <p> Output</p> <p> After each cut print on a single line the area of the maximum available glass fragment in mm<span><span>2</span></span>.</p> <p> </p> <p> Sample test(s)</p> <p> </p> <p> </p> <p> input</p> <pre class="brush:php;toolbar:false">4 3 4 H 2 V 2 V 3 V 1
output
8 4 4 2
input
7 6 5 H 4 V 3 V 5 H 2 V 1
output
28 16 12 6 4
Note
Picture for the first sample test:


有一块大大的玻璃~~~
每次横着或者竖着砍一刀,砍完不要拿走,下一道也得砍到这条线所在的所有部件。
每次砍完之后输出当前碎片中最大面积的部件的面积。
首先要知道的是,千万别一个一个部件的比较面积大小哦,因为每刀都是垂直或者水平的,所以每部分的面积都等于所对应的长边线段和短边线段的积。
即:我们要求的其实只是长边上的最长线段和短边上的最长线段,输出它们的积。
嘛,也顺带用两个例程说明下这三个函数的使用方法吧~ 毕竟set感觉并不是那么太常见(灵活使用的大大们请无视这句^_^)
// erasing from multiset #include <iostream> #include <set> int main () { std::multiset<int> mymultiset; std::multiset<int>::iterator it; // insert some values: mymultiset.insert (40); // 40 for (int i=1; i<br> <pre class="brush:php;toolbar:false">// set::find #include <iostream> #include <set> int main () { std::set<int> myset; std::set<int>::iterator it; // set some initial values: for (int i=1; i<br> <pre class="brush:php;toolbar:false">// set::insert (C++98) #include <iostream> #include <set> int main () { std::set<int> myset; std::set<int>::iterator it; std::pair<:set>::iterator,bool> ret; // set some initial values: for (int i=1; i<br> 说完了函数的使用方法,嘛,就来看看这题的解题Code吧 <h3 id="Code">Code:</h3> <pre class="brush:php;toolbar:false">#include <set> #include <cmath> #include <cctype> #include <cstdio> #include <string> #include <cstdlib> #include <cstring> #include <iostream> #include <algorithm> using namespace std; typedef long long ll; #define i insert char ch; int n,w,h,t; set<int> x,y,*s; set<int>::iterator l,r; multiset<int> lx,ly,*ls; int main() { cin>>w>>h>>n; x.i(0);x.i(w);y.i(0);y.i(h);lx.i(w);ly.i(h); for (int j=1; j>ch>>t; if (ch=='H') {s=&y; ls=&ly;} else {s=&x; ls=&lx;} s->i(t); l=r=s->find(t); l--; r++; ls->erase(ls->find(*r-*l)); ls->i(t-*l); ls->i(*r-t); cout<br> <br> <p><br> </p> <p><br> </p> <p><br> </p> <p><br> </p> </int></int></int></algorithm></iostream></cstring></cstdlib></string></cstdio></cctype></cmath></set>

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











チームファイト タクティクスの各シーズンは約 3 か月続きます。現在、チームファイト タクティクス S11 シーズンの米国テスト サーバーは 3 月 7 日に更新および開始され、チームファイト タクティクスとゴールデン ショベルは 3 月 21 日に更新および開始されます。シーズンはおそらく7月上旬に終了するでしょう。 TFT S11 はいつ終了しますか? 回答: 7 月上旬。 1. S11 シーズンは 7 月上旬に終了すると推測されており、具体的な終了日は公式発表を待つ必要があります。 2. Teamfight Tactics の各シーズンは約 3 か月続きます。 3. チームファイト タクティクス S11 シーズンの米国テスト サーバーは 3 月 7 日に更新および開始され、チームファイト タクティクスとゴールデン ショベルは 3 月 21 日に更新および開始されます。 4. 新しいゲームプレイメカニズムが S11 シーズンに追加され、20 を超える新しいオーン アーティファクトが追加されます。

コンピューターを使用すると、バックグラウンドで実行され続けてシステムの速度が低下する多くの問題が必然的に発生します。現時点で、win11 でバックグラウンドで実行を終了するショートカット キーはありますか?実際には、開くことしかできません。ショートカット キーでタスク マネージャーを起動し、閉じます。 win11 でバックグラウンド実行を終了するショートカット キー: 1. まず、キーボードの「ctrl+shift+esc」ショートカット キーの組み合わせを押して、タスク マネージャー ページを開きます。 2. [タスク マネージャー] ページで、マウスを使用して [名前] ボタン オプションをクリックし、選択します。 3. ページがジャンプした後、現在実行中のすべての「バックグラウンド プロセス」を直接確認できます。 4.実際のニーズに応じて、閉じたい背景を選択し、オプションの右下隅にある「タスクの終了」をクリックします。

多くの友人は、コンピューターを使用しているときに特定のソフトウェアが停止することに遭遇します。コンピュータが動かない場合は、タスク マネージャーを呼び出してプロセスを終了する必要があります。呼び出した後、ショートカット キーを使用してタスクを終了するにはどうすればよいですか? 最も簡単なのは削除することですが、他にもいくつかの方法があります。以下をご覧ください。タスク マネージャーでタスクを終了するショートカット キーを使用する方法 タスク マネージャーのショートカット キーを使用する方法: 1. キーの組み合わせ「Ctrl+Shift+ESC」。 2. キーの組み合わせ「Ctrl+Alt+Delete」。タスクを終了するショートカットキー 1. 終了するタスクを選択し、「削除」をクリックします。 2. 終了する必要があるタスクを選択し、「alt+e」キーの組み合わせを押します。

div の角が欠けていることを認識するための CSS メソッド: 1. HTML サンプル ファイルを作成し、div を定義します; 2. div の幅と高さの背景色を設定します; 3. 削除する必要がある div に疑似クラスを追加します隅に配置し、擬似クラスを背景色と同じ色を使用するように設定し、45 度回転して、削除する必要がある隅に配置します。

オフィスで Tencent Conference ソフトウェアをよく使用しますか? Tencent Conference で会議を終了する方法を知っていますか? 次に、エディターが Tencent Conference での会議を終了するための具体的な操作を表示します。これに興味のあるユーザーは、次のこともできます。以下を見てみましょう。コンピュータの電源を入れ、ダブルクリックして Tencent ミーティングに入り、ログインします。クリックしてクイック ミーティングに入り、ミーティングの終了ボタンをクリックします。

はじめに 最近 GitHub に ChatGPTAPI をベースにしたブラウザスクリプト openai-translator が登場しました 短期間でスターが 12k に達しました 翻訳だけでなく磨きや要約機能もサポートしています ブラウザプラグに加えて-ins, tauri パッケージも使用します。デスクトップ クライアントをお持ちの場合は、tauri が Rust 部分を使用するという事実を除けば、ブラウザ部分の実装はまだ比較的簡単です。今日は手動で実装します。 openAI によって提供されるインターフェイス。たとえば、次のコードをコピーし、ブラウザ コンソールでリクエストを開始して変換を完了できます。 //Example constOPENAI_API_KEY="s

iframe と div の違いは、iframe は主に外部コンテンツを導入するために使用され、他の Web サイトからコンテンツをロードしたり、Web ページを複数の領域に分割したりできます。各領域には独自の独立した閲覧コンテキストがあり、div は主に分割および分割するために使用されます。コンテンツを整理し、レイアウトとスタイルを制御するためのブロック。

div ボックス モデルは、Web ページのレイアウトに使用されるモデルです。Web ページ内の要素を長方形のボックスとして扱います。このモデルには、コンテンツ領域、パディング、ボーダー、マージンの 4 つの部分が含まれています。 div ボックス モデルの利点は、Web ページのレイアウトと要素間の間隔を簡単に制御できることであり、コンテンツ領域、内側の余白、境界線、外側の余白のサイズを調整することで、さまざまなレイアウト効果を実現できます。ボックス モデルには、CSS と JavaScript を通じてボックスのスタイルと動作を動的に変更できるいくつかのプロパティとメソッドも用意されています。
