Table des matières
A. Playing with Paper
Code:
B. Error Correct System
C. Glass Carving
Maison base de données tutoriel mysql 第三十次codeforces竞技结束 #296 Div 2

第三十次codeforces竞技结束 #296 Div 2

Jun 07, 2016 pm 03:07 PM
div 结束

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

第三十次codeforces竞技结束 #296 Div 2

 

 

# Name    
A

Playing with Paper

standard input/output

2 s, 256 MB
第三十次codeforces竞技结束 #296 Div 2 第三十次codeforces竞技结束 #296 Div 2 第三十次codeforces竞技结束 #296 Div 2 x2429
B

Error Correct System

standard input/output

2 s, 256 MB
第三十次codeforces竞技结束 #296 Div 2 第三十次codeforces竞技结束 #296 Div 2 第三十次codeforces竞技结束 #296 Div 2 x953
C

Glass Carving

standard input/output

2 s, 256 MB
第三十次codeforces竞技结束 #296 Div 2 第三十次codeforces竞技结束 #296 Div 2 第三十次codeforces竞技结束 #296 Div 2 x584

第三十次……好想到紫啊好想紫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.

第三十次codeforces竞技结束 #296 Div 2

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 ab (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
Copier après la connexion

output

2
Copier après la connexion

input

10 7
Copier après la connexion

output

6
Copier après la connexion

input

1000000000000 1
Copier après la connexion

output

1000000000000
Copier après la connexion

Note

Pictures to the first and second sample test.

第三十次codeforces竞技结束 #296 Div 2


说一张长方形的纸~,每次都以较短边为边长裁一个正方形下来折个纸船,问长宽已知的长方形纸能折多少个纸船。

我想说……做题的时候有这个图么!!!

每次如果裁剪的效果没有达到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
Copier après la connexion

output

1
4 6
Copier après la connexion

input

6
wookie
cookie
Copier après la connexion

output

1
-1 -1
Copier après la connexion

input

4
petr
egor
Copier après la connexion

output

2
1 2
Copier après la connexion

input

6
double
bundle
Copier après la connexion

output

2
4 1
Copier après la connexion

Note

In the second test it is acceptable to print i?=?2j?=?3.


所谓海明距离,就是字符串s和字符串t字符不同的位置个数,比如acm和acg,有一个字符不同,所以是1.

题目问,如果最多允许把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
Copier après la connexion

output

8
4
4
2
Copier après la connexion

input

7 6 5
H 4
V 3
V 5
H 2
V 1
Copier après la connexion

output

28
16
12
6
4
Copier après la connexion

Note

Picture for the first sample test:

第三十次codeforces竞技结束 #296 Div 2
Picture for the second sample test:
第三十次codeforces竞技结束 #296 Div 2
 

有一块大大的玻璃~~~

每次横着或者竖着砍一刀,砍完不要拿走,下一道也得砍到这条线所在的所有部件。

每次砍完之后输出当前碎片中最大面积的部件的面积。

首先要知道的是,千万别一个一个部件的比较面积大小哦,因为每刀都是垂直或者水平的,所以每部分的面积都等于所对应的长边线段和短边线段的积。

即:我们要求的其实只是长边上的最长线段和短边上的最长线段,输出它们的积。

嘛,也顺带用两个例程说明下这三个函数的使用方法吧~ 毕竟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>
Copier après la connexion
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quand Teamfight Tactics S11 se terminera-t-il ? Quand Teamfight Tactics S11 se terminera-t-il ? Mar 18, 2024 pm 03:16 PM

Chaque saison de Teamfight Tactics dure environ trois mois. Actuellement, le serveur de test américain de la saison Teamfight Tactics S11 a été mis à jour et lancé le 7 mars. Teamfight Tactics et Golden Shovel ont été mis à jour et lancés le 21 mars. se terminera probablement début juillet. Quand le TFT S11 se terminera-t-il ? Réponse : début juillet. 1. On suppose que la saison S11 se terminera début juillet. La date de fin précise doit attendre l'annonce officielle. 2. Chaque saison de Teamfight Tactics dure environ trois mois. 3. Le serveur de test américain de la saison Teamfight Tactics S11 sera mis à jour et lancé le 7 mars, et Teamfight Tactics et Golden Shovel seront mis à jour et lancés le 21 mars. 4. Un nouveau mécanisme de jeu sera ajouté à la saison S11 et plus de 20 nouveaux artefacts Ornn seront ajoutés.

Comment désactiver rapidement les touches de raccourci exécutées en arrière-plan de Win11 ? Comment désactiver rapidement les touches de raccourci exécutées en arrière-plan de Win11 ? Dec 28, 2023 am 09:54 AM

Lorsque nous utilisons des ordinateurs, nous rencontrerons inévitablement de nombreux problèmes qui continuent de fonctionner en arrière-plan, ce qui ralentit le système. À l'heure actuelle, existe-t-il une touche de raccourci pour mettre fin au fonctionnement en arrière-plan dans Win11. En fait, nous ne pouvons qu'ouvrir ? le gestionnaire de tâches avec la touche de raccourci, puis fermez-le dans Backstage. Touches de raccourci pour mettre fin à l'exécution en arrière-plan dans Win11 : 1. Tout d'abord, nous appuyons sur la combinaison de touches de raccourci clavier "ctrl+shift+esc" pour ouvrir la page du gestionnaire de tâches. 2. Dans la page Gestionnaire des tâches, utilisez la souris pour cliquer et sélectionner l'option du bouton "Nom". 3. Une fois la page sautée, nous pouvons voir directement tous les « processus en arrière-plan » en cours d'exécution. 4. En fonction des besoins réels, nous sélectionnons l'arrière-plan que nous souhaitons fermer et cliquons sur "Fin de tâche" dans le coin inférieur droit de l'option.

Comment utiliser les touches de raccourci du gestionnaire de tâches de l'ordinateur pour terminer une tâche Comment utiliser les touches de raccourci du gestionnaire de tâches de l'ordinateur pour terminer une tâche Jan 02, 2024 pm 01:34 PM

De nombreux amis rencontrent certains logiciels bloqués lors de l’utilisation de leur ordinateur. Si l'ordinateur ne peut pas bouger, vous devez appeler le gestionnaire de tâches pour terminer le processus. Après l'avoir appelé, comment utiliser les touches de raccourci pour terminer la tâche. Le plus simple est de supprimer, et il existe d'autres méthodes. regarde. Comment utiliser les touches de raccourci pour terminer des tâches dans le Gestionnaire des tâches Comment utiliser les touches de raccourci pour le Gestionnaire des tâches : 1. Combinaison de touches "Ctrl+Shift+ESC". 2. Combinaison de touches "Ctrl+Alt+Suppr". Touches de raccourci pour terminer les tâches 1. Sélectionnez la tâche à terminer et cliquez sur "Supprimer". 2. Sélectionnez la tâche à terminer et appuyez sur la combinaison de touches "alt+e".

Comment utiliser CSS pour se rendre compte qu'il manque un coin à un div Comment utiliser CSS pour se rendre compte qu'il manque un coin à un div Jan 30, 2023 am 09:23 AM

Méthode CSS pour réaliser qu'il manque un coin à un div : 1. Créez un exemple de fichier HTML et définissez un div ; 2. Définissez la couleur d'arrière-plan de la largeur et de la hauteur du div 3. Ajoutez une pseudo-classe au div qui doit être supprimé ; un coin et définissez la pseudo-classe sur Utiliser la même couleur que la couleur d'arrière-plan, puis faites-la pivoter de 45 degrés, puis positionnez-la sur le coin qui doit être supprimé.

Comment mettre fin à une réunion dans Tencent Meeting - opérations spécifiques pour mettre fin à une réunion dans Tencent Meeting Comment mettre fin à une réunion dans Tencent Meeting - opérations spécifiques pour mettre fin à une réunion dans Tencent Meeting Mar 05, 2024 pm 12:16 PM

Utilisez-vous souvent le logiciel Tencent Conference dans votre bureau ? Alors, savez-vous comment mettre fin à une réunion dans Tencent Conference ? Ensuite, l'éditeur vous présentera les opérations spécifiques de fin d'une réunion dans Tencent Conference. Jetons un coup d'œil ci-dessous. Allumez l'ordinateur, double-cliquez pour accéder à Tencent Meeting, puis connectez-vous, cliquez pour accéder à la réunion rapide et cliquez sur le bouton de fin de réunion.

Implémentation d'un script de navigateur de traduction de marquage de mots basé sur l'API ChatGPT Implémentation d'un script de navigateur de traduction de marquage de mots basé sur l'API ChatGPT May 01, 2023 pm 03:28 PM

Préface Récemment, il existe un script de navigateur basé sur ChatGPTAPI sur GitHub, openai-translator. En peu de temps, l'étoile a atteint 12k. En plus de prendre en charge la traduction, elle prend également en charge les fonctions de polissage et de synthèse. -ins, il utilise également le packaging tauri. Si vous avez un client de bureau, outre le fait que tauri utilise la partie rust, la partie navigateur est encore relativement simple à implémenter. Aujourd'hui, nous allons l'implémenter manuellement. L'interface fournie par openAI, par exemple, nous pouvons copier le code suivant et lancer une requête dans la console du navigateur pour terminer la traduction //Exemple constOPENAI_API_KEY="s

Quel est le modèle de boîte de division ? Quel est le modèle de boîte de division ? Oct 09, 2023 pm 05:15 PM

Le modèle de boîte div est un modèle utilisé pour la mise en page d'une page Web. Il traite les éléments d'une page Web comme des boîtes rectangulaires. Ce modèle contient quatre parties : la zone de contenu, le remplissage, la bordure et la marge. L'avantage du modèle de boîte div est qu'il peut facilement contrôler la mise en page de la page Web et l'espacement entre les éléments. En ajustant la taille de la zone de contenu, la marge intérieure, la bordure et la marge extérieure, divers effets de mise en page peuvent être obtenus. Le modèle de boîte fournit également certaines propriétés et méthodes permettant de modifier dynamiquement le style et le comportement de la boîte via CSS et JavaScript.

Quelle est la différence entre iframe et div Quelle est la différence entre iframe et div Aug 28, 2023 am 11:46 AM

La différence entre iframe et div est que iframe est principalement utilisé pour introduire du contenu externe, qui peut charger du contenu provenant d'autres sites Web ou diviser une page Web en plusieurs zones. Chaque zone a son propre contexte de navigation indépendant, tandis que div est principalement utilisé pour diviser et div. organiser le contenu. bloc pour la mise en page et le contrôle du style.

See all articles