search
HomeDatabaseMysql Tutorial第三十次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

第三十次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

output

2

input

10 7

output

6

input

1000000000000 1

output

1000000000000

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

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?=?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

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:

第三十次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>
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
云顶之弈s11什么时候结束云顶之弈s11什么时候结束Mar 18, 2024 pm 03:16 PM

云顶之弈的每个赛季都大约3个多月左右,目前云顶之弈S11赛季美测服于3月7日更新上线,云顶之弈和金铲铲于3月21日更新上线,推测s11赛季大概于7月初结束。云顶之弈s11什么时候结束答:7月初。1、推测s11赛季大概于7月初结束,具体的结束日期还需要等待官方公布。2、云顶之弈每个赛季都大约3个多月左右。3、云顶之弈S11赛季美测服于3月7日更新上线,云顶之弈和金铲铲于3月21日更新上线。4、S11赛季将加入一个全新的玩法机制,此外还将增加20多种新的奥恩神器。

如何快速关闭Win11后台运行的快捷键?如何快速关闭Win11后台运行的快捷键?Dec 28, 2023 am 09:54 AM

我们在用电脑的时候,难免会遇到一堆后台保持运行,导致拖慢了系统速度的问题,这时候有没有win11结束后台运行快捷键呢,其实我们只能快捷键打开任务管理器再关闭后台。win11结束后台运行快捷键:1、首先,我们按键盘“ctrl+shift+esc”组合快捷键,从而打开任务管理器页面。2、在任务管理器页面中,使用鼠标点击选择“名称”按钮选项。3、之后页面跳转,我们就可以直接看到当前运行的所有“后台进程”了。4、根据实际需要我们选择想要关闭的后台,在该选项的右下角点击“结束任务”即可。

使用电脑任务管理器的快捷键来结束任务的方法使用电脑任务管理器的快捷键来结束任务的方法Jan 02, 2024 pm 01:34 PM

很多小伙伴在使用电脑的时候遇见某个软件卡住。电脑动不了的情况,这个时候就需要调出任务管理器来结束这个进程,调出来后该如何使用快捷键结束这个任务呢?最简单的莫过于delete,还有其他的方法,下面一起来看看吧。任务管理器结束任务快捷键使用方法任务管理器的快捷键使用方法:1、组合键“Ctrl+Shift+ESC”。2、组合键“Ctrl+Alt+Delete”。结束任务的快捷键1、选定需要结束的任务点击“Delete”。2、选择需要结束的任务,组合键“alt+e”。

css怎么实现div缺一个角css怎么实现div缺一个角Jan 30, 2023 am 09:23 AM

css实现div缺一个角的方法:1、创建一个HTML示例文件,并定义一个div;2、给div设置宽高背景色;3、给需要删除一角的div增加一个伪类,将伪类设置成跟背景色一样的颜色,然后旋转45度,再定位到需要去除的那个角即可。

腾讯会议如何结束会议-腾讯会议结束会议的具体操作腾讯会议如何结束会议-腾讯会议结束会议的具体操作Mar 05, 2024 pm 12:16 PM

你们在办公中是不是也经常使用腾讯会议软件呀?那么你们晓得腾讯会议如何结束会议吗?接下来,小编就为大伙带来了腾讯会议结束会议的具体操作,对此感兴趣的用户一同来下文看看吧。打开电脑,双击进入腾讯会议,然后登录点击进入快速会议点击结束会议按钮即可

基于 ChatGPT API 的划词翻译浏览器脚本实现基于 ChatGPT API 的划词翻译浏览器脚本实现May 01, 2023 pm 03:28 PM

前言最近GitHub上有个基于ChatGPTAPI的浏览器脚本,openai-translator,短时间内star冲到了12k,功能上除了支持翻译外,还支持润色和总结功能,除了浏览器插件外,还使用了tauri打包了一个桌面客户端,那抛开tauri是使用rust部分,那浏览器部分实现还是比较简单的,今天我们就来手动实现一下。openAI提供的接口比如我们可以复制以下代码,在浏览器控制台中发起请求,就可以完成翻译//示例constOPENAI_API_KEY="s

div与span的区别有哪些div与span的区别有哪些Nov 02, 2023 pm 02:29 PM

区别有:1、div是一个块级元素,span是一个行内元素;2、div会自动占据一行,span则不会自动换行;3、div用于包裹比较大的结构和布局,span用于包裹文本或者其他行内元素;4、div可以包含其他块级元素和行内元素,span可以包含其他行内元素。

div盒模型是什么div盒模型是什么Oct 09, 2023 pm 05:15 PM

div盒模型是一种用于网页布局的模型,它将网页中的元素视为一个个矩形的盒子,这个模型包含了四个部分:内容区域、内边距、边框和外边距。div盒模型的好处是可以方便地控制网页布局和元素之间的间距,通过调整内容区域、内边距、边框和外边距的大小,可以实现各种不同的布局效果,盒模型也提供了一些属性和方法,可以通过CSS和JavaScript来动态地改变盒子的样式和行为。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!