第二十九次codeforces竞技结束 #293 Div 2
Problems # Name A Vitaly and Strings standard input/output 1 s, 256 MB x2731 B Tanya and Postcard standard input/output 2 s, 256 MB x2749 C Anya and Smartphone standard input/output 1 s, 256 MB x2299 D Ilya and Escalator standard input/out
Problems
# | Name | ||
---|---|---|---|
A |
Vitaly and Strings
standard input/output 1 s, 256 MB |
![]() ![]() |
![]() |
B |
Tanya and Postcard
standard input/output 2 s, 256 MB |
![]() ![]() |
![]() |
C |
Anya and Smartphone
standard input/output 1 s, 256 MB |
![]() ![]() |
![]() |
D |
Ilya and Escalator
standard input/output 2 s, 256 MB |
![]() ![]() |
![]() |
向来赛完不写解题报告就会时运Down,以后不敢了Q^Q
这场比赛是相对较为简单,容易想到思路,适宜冲紫名的一场,但可惜Pretest数据可能弱了些让大家过的太爽了于是FST就多了起来反而掉分现象普及。
那么,一个个来看看吧
A. Vitaly and Strings
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output
Vitaly is a diligent student who never missed a lesson in his five years of studying in the university. He always does his homework on time and passes his exams in time.
During the last lesson the teacher has provided two strings s and t to Vitaly. The strings have the same length, they consist of lowercase English letters, string s is lexicographically smaller than string t. Vitaly wondered if there is such string that is lexicographically larger than string s and at the same is lexicographically smaller than string t. This string should also consist of lowercase English letters and have the length equal to the lengths of strings s and t.
Let's help Vitaly solve this easy problem!
Input
The first line contains string s (1?≤?|s|?≤?100), consisting of lowercase English letters. Here, |s| denotes the length of the string.
The second line contains string t (|t|?=?|s|), consisting of lowercase English letters.
It is guaranteed that the lengths of strings s and t are the same and string s is lexicographically less than string t.
Output
If the string that meets the given requirements doesn't exist, print a single string "No such string" (without the quotes).
If such string exists, print it. If there are multiple valid strings, you may print any of them.
Sample test(s)
input
a c
output
b
input
aaa zzz
output
kkk
input
abcdefg abcdefh
output
No such string
Note
String s?=?s1s2... sn is said to be lexicographically smaller than t?=?t1t2... tn, if there exists such i, that s1?=?t1,?s2?=?t2,?... si?-?1?=?ti?-?1,?si?ti.
简单来说,给了两个字符串,问他们之间存在字典序夹在二者之间的字符串嘛?有的话随便输出一个,没有的话输出“No such string”,题目中已经告知了s一定字典序小于t,那么s的最后一位加一看看是不是和t一样不就行了嘛?一样就是不存在,不一样就输出咯?
嘿嘿,有坑哦~ 如果末位是z怎么办,如果末位是两个、三个……n个z怎么办呢?这不是数字可以9变成0然后进位哦~ 对了,我们自己用while写一个类似进位的操作不久好了嘛?
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() { string s,t; cin>>s>>t; int l=s.length()-1; while(s[l]=='z') { s[l]='a'; l--; } s[l]=s[l]+1; if(s==t) cout<br> <p> </p> <p> </p> <p> </p> <p> </p> <p> </p> <p> </p> <h2 id="B-Tanya-and-Postcard">B. Tanya and Postcard</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> Little Tanya decided to present her dad a postcard on his Birthday. She has already created a message — string <span><em>s</em></span> of length <span><em>n</em></span>, consisting of uppercase and lowercase English letters. Tanya can't write yet, so she found a newspaper and decided to cut out the letters and glue them into the postcard to achieve string <span><em>s</em></span>. The newspaper contains string <span><em>t</em></span>, consisting of uppercase and lowercase English letters. We know that the length of string <span><em>t</em></span> greater or equal to the length of the string <span><em>s</em></span>.</p> <p> The newspaper may possibly have too few of some letters needed to make the text and too many of some other letters. That's why Tanya wants to cut some <span><em>n</em></span> letters out of the newspaper and make a message of length exactly <span><em>n</em></span>, so that it looked as much as possible like <span><em>s</em></span>. If the letter in some position has correct value and correct letter case (in the string <span><em>s</em></span> and in the string that Tanya will make), then she shouts joyfully "<span>YAY!</span>", and if the letter in the given position has only the correct value but it is in the wrong case, then the girl says "<span>WHOOPS</span>".</p> <p> Tanya wants to make such message that lets her shout "<span>YAY!</span>" as much as possible. If there are multiple ways to do this, then her second priority is to maximize the number of times she says "<span>WHOOPS</span>". Your task is to help Tanya make the message.</p> <p> </p> <p> Input</p> <p> The first line contains line <span><em>s</em></span> (<span>1?≤?|<em>s</em>|?≤?2·10<span>5</span></span>), consisting of uppercase and lowercase English letters — the text of Tanya's message.</p> <p> The second line contains line <span><em>t</em></span> (<span>|<em>s</em>|?≤?|<em>t</em>|?≤?2·10<span>5</span></span>), consisting of uppercase and lowercase English letters — the text written in the newspaper.</p> <p> Here <span>|<em>a</em>|</span> means the length of the string <span><em>a</em></span>.</p> <p> </p> <p> Output</p> <p> Print two integers separated by a space:</p> <ul> <li> the first number is the number of times Tanya shouts "<span>YAY!</span>" while making the message,</li> <li> the second number is the number of times Tanya says "<span>WHOOPS</span>" while making the message.</li> </ul> <p> </p> <p> Sample test(s)</p> <p> </p> <p> </p> <p> input</p> <pre class="brush:php;toolbar:false">AbC DCbA
output
3 0
input
ABC abc
output
0 3
input
abacaba AbaCaBA
output
3 4
要求YAY最多的情况中Whoops最多时的两者数量。
简单的说,给定两个字符串,问在第二个字符串中有多少个a中的严格区分大小写字符,排除掉这些字符后不严格区分大小写的有多少个。
因为字符串不长,可以暴力枚举。
先读一遍s得知需要哪些东西(这里想想我当时为啥hash呢,map简直轻松愉快呀,读者可以试试使用map
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 cntl[26]={0},cntu[26]={0}; //cnt int nedl[26]={0},nedu[26]={0}; //need int main() { int yay=0,whoops=0; string s,t; cin>>s>>t; for(int i=0;i<s.length if nedu else nedl for i="0;i<t.length();i++)" cntu cntl int p="min(nedl[i],cntl[i]);" cout return><br> <p> </p> <h2 id="C-Anya-and-Smartphone">C. Anya and Smartphone</h2> <p> </p> <p> time limit per test</p> 1 second <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> Anya has bought a new smartphone that uses <span>Berdroid</span> operating system. The smartphone menu has exactly <span><em>n</em></span> applications, each application has its own icon. The icons are located on different screens, one screen contains <span><em>k</em></span> icons. The icons from the first to the <span><em>k</em></span>-th one are located on the first screen, from the <span>(<em>k</em>?+?1)</span>-th to the <span>2<em>k</em></span>-th ones are on the second screen and so on (the last screen may be partially empty).</p> <p> Initially the smartphone menu is showing the screen number <span>1</span>. To launch the application with the icon located on the screen <span><em>t</em></span>, Anya needs to make the following gestures: first she scrolls to the required screen number <span><em>t</em></span>, by making <span><em>t</em>?-?1</span> gestures (if the icon is on the screen <span><em>t</em></span>), and then make another gesture — press the icon of the required application exactly once to launch it.</p> <p> After the application is launched, the menu returns to the first screen. That is, to launch the next application you need to scroll through the menu again starting from the screen number <span>1</span>.</p> <p> All applications are numbered from <span>1</span> to <span><em>n</em></span>. We know a certain order in which the icons of the applications are located in the menu at the beginning, but it changes as long as you use the operating system. <span>Berdroid</span> is intelligent system, so it changes the order of the icons by moving the more frequently used icons to the beginning of the list. Formally, right after an application is launched, Berdroid swaps the application icon and the icon of a preceding application (that is, the icon of an application on the position that is smaller by one in the order of menu). The preceding icon may possibly be located on the adjacent screen. The only exception is when the icon of the launched application already occupies the first place, in this case the icon arrangement doesn't change.</p> <p> Anya has planned the order in which she will launch applications. How many gestures should Anya make to launch the applications in the planned order?</p> <p> Note that one application may be launched multiple times.</p> <p> </p> <p> Input</p> <p> The first line of the input contains three numbers <span><em>n</em>,?<em>m</em>,?<em>k</em></span> (<span>1?≤?<em>n</em>,?<em>m</em>,?<em>k</em>?≤?10<span>5</span></span>) — the number of applications that Anya has on her smartphone, the number of applications that will be launched and the number of icons that are located on the same screen.</p> <p> The next line contains <span><em>n</em></span> integers, permutation <span><em>a</em><span>1</span>,?<em>a</em><span>2</span>,?...,?<em>a</em><span><em>n</em></span></span> — the initial order of icons from left to right in the menu (from the first to the last one), <span><em>a</em><span><em>i</em></span></span> — is the id of the application, whose icon goes <span><em>i</em></span>-th in the menu. Each integer from <span>1</span> to <span><em>n</em></span> occurs exactly once among <span><em>a</em><span><em>i</em></span></span>.</p> <p> The third line contains <span><em>m</em></span> integers <span><em>b</em><span>1</span>,?<em>b</em><span>2</span>,?...,?<em>b</em><span><em>m</em></span>(1?≤?<em>b</em><span><em>i</em></span>?≤?<em>n</em>)</span> — the ids of the launched applications in the planned order. One application may be launched multiple times.</p> <p> </p> <p> Output</p> <p> Print a single number — the number of gestures that Anya needs to make to launch all the applications in the desired order.</p> <p> </p> <p> Sample test(s)</p> <p> </p> <p> </p> <p> input</p> <pre class="brush:php;toolbar:false">8 3 3 1 2 3 4 5 6 7 8 7 8 1
output
7
input
5 4 2 3 1 5 2 4 4 4 4 4
output
8
Note
In the first test the initial configuration looks like (123)(456)(78), that is, the first screen contains icons of applications 1,?2,?3, the second screen contains icons 4,?5,?6, the third screen contains icons 7,?8.
After application 7 is launched, we get the new arrangement of the icons — (123)(457)(68). To launch it Anya makes 3gestures.
After application 8 is launched, we get configuration (123)(457)(86). To launch it Anya makes 3 gestures.
After application 1 is launched, the arrangement of icons in the menu doesn't change. To launch it Anya makes 1 gesture.
In total, Anya makes 7 gestures.
说有个智能手机,上面有n个APP,我要点其中的m个,每页最多可以放k个APP。
点击某个APP需要的手势的个数其实就是(pos/k)+(pos%k==0?0:1),即这个APP当前所在的位置除以每页最多放置的APP数,向上取整,因为我们需要滑动(当前所在页数-1)+点击1次=当前所在页数。
然后就是每次点击要前移一位的实现了:
if(pos>1) { int t=fdnum[pos-1]; fdnum[pos-1]=now; fdpos[now]=pos-1; fdnum[pos]=t; fdpos[t]=pos; }
我用的方法是:数组1:每个位置对应当前位置的APP编号,数组2:每个APP编号当前所在的位置,然后借助临时变量t进行swap操作。
当然别忘了他就在第一页的时候不用和前一个调换位置哦。
然后,坑来了——
孩子们永远是那句话……int不是好东西啊,LL大法好啊,动不动int就溢出了烦不烦呢!明明就前300可以紫名了你就是不开心溢出让我FST,叹气……
Code:
#include <map> #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; } map<int> fdpos,fdnum; //num->pos & pos->num int main() { fdpos.clear(); fdnum.clear(); long long ans=0; // LL大法好…… int n,m,k; cin>>n>>m>>k; for(int i=1;i1) { int t=fdnum[pos-1]; fdnum[pos-1]=now; fdpos[now]=pos-1; fdnum[pos]=t; fdpos[t]=pos; } } cout<br> <p> </p> <p> </p> <p> </p> <p> </p> <p> </p> <p> </p> <h2 id="D-Ilya-and-Escalator">D. Ilya and Escalator</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> Ilya got tired of sports programming, left university and got a job in the subway. He was given the task to determine the escalator load factor.</p> <p> Let's assume that <span><em>n</em></span> people stand in the queue for the escalator. At each second one of the two following possibilities takes place: either the first person in the queue enters the escalator with probability <span><em>p</em></span>, or the first person in the queue doesn't move with probability <span>(1?-?<em>p</em>)</span>, paralyzed by his fear of escalators and making the whole queue wait behind him.</p> <p> Formally speaking, the <span><em>i</em></span>-th person in the queue cannot enter the escalator until people with indices from <span>1</span> to <span><em>i</em>?-?1</span> inclusive enter it. In one second only one person can enter the escalator. The escalator is infinite, so if a person enters it, he never leaves it, that is he will be standing on the escalator at any following second. Ilya needs to count the expected value of the number of people standing on the escalator after <span><em>t</em></span> seconds.</p> <p> Your task is to help him solve this complicated task.</p> <p> </p> <p> Input</p> <p> The first line of the input contains three numbers <span><em>n</em>,?<em>p</em>,?<em>t</em></span> (<span>1?≤?<em>n</em>,?<em>t</em>?≤?2000</span>, <span>0?≤?<em>p</em>?≤?1</span>). Numbers <span><em>n</em></span> and <span><em>t</em></span> are integers, number <span><em>p</em></span>is real, given with exactly two digits after the decimal point.</p> <p> </p> <p> Output</p> <p> Print a single real number — the expected number of people who will be standing on the escalator after <span><em>t</em></span> seconds. The absolute or relative error mustn't exceed <span>10<span>?-?6</span></span>.</p> <p> </p> <p> Sample test(s)</p> <p> </p> <p> </p> <p> input</p> <pre class="brush:php;toolbar:false">1 0.50 1
output
0.5
input
1 0.50 4
output
0.9375
input
4 0.20 2
output
0.4
啊对了题意啊题意……
有个无限长的电梯,有n个人一列纵队在排队上电梯,每个人只能在前头都没人了的时候才能上电梯,每秒钟,有p的概率排在第一的人上了电梯,问:t秒后,电梯上人数的数学期望……
数学你好……概率学啦……
用dp[i][j]来表示当i个人排队时在第t秒电梯上人数的数学期望。
那么我们知道dp[i][j]应该等于
当[(i-1个人,j-1秒)时的期望+1] * p (这个人上去了)
加上 当[(i个人,j-1秒)时的期望 * (1-p) (这个人没上去)
具体的看看代码吧
Code:
#include<bits> double dp[2005][2005]; int main() { int n,t,i; double p; scanf("%d%lf%d",&n,&p,&t); for(i=1;i<br> <br> <p><br> </p> <p><br> </p> <p><br> </p> <p><br> </p> <p><br> </p> <p><br> </p> </bits>

핫 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
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Teamfight Tactics의 각 시즌은 약 3개월 동안 진행됩니다. 현재 Teamfight Tactics S11 시즌의 미국 테스트 서버는 3월 7일에 업데이트되어 출시될 예정입니다. Teamfight Tactics와 Golden Shovel은 3월 21일에 업데이트되어 출시될 예정입니다. 시즌 아마도 7월 초에 끝날 것 같습니다. TFT S11은 언제 종료되나요? 답변: 7월 초. 1. S11 시즌이 7월 초에 종료될 것으로 예상되며, 구체적인 종료일은 공식 발표를 기다려봐야 할 것 같습니다. 2. Teamfight Tactics의 각 시즌은 약 3개월 동안 지속됩니다. 3. Teamfight Tactics S11 시즌의 미국 테스트 서버는 3월 7일에 업데이트되어 출시될 예정이며, Teamfight Tactics와 Golden Shovel은 3월 21일에 업데이트되어 출시될 예정입니다. 4. S11 시즌에는 새로운 게임플레이 메커니즘이 추가되고, 20개 이상의 오른 아티팩트가 추가됩니다.

컴퓨터를 사용하다 보면 필연적으로 백그라운드에서 계속 실행되어 시스템 속도가 느려지는 문제가 많이 발생하게 되는데, 이때 win11에서 백그라운드 실행을 종료할 수 있는 단축키가 과연 있을까요? 단축키를 사용하여 작업 관리자를 닫은 다음 Backstage를 닫습니다. win11에서 백그라운드 실행을 종료하는 단축키: 1. 먼저 키보드의 "ctrl+shift+esc" 단축키 조합을 눌러 작업 관리자 페이지를 엽니다. 2. 작업 관리자 페이지에서 마우스를 사용하여 "이름" 버튼 옵션을 클릭하고 선택합니다. 3. 페이지 이동 후 현재 실행 중인 모든 "백그라운드 프로세스"를 직접 볼 수 있습니다. 4. 실제 필요에 따라 닫으려는 배경을 선택하고 옵션 오른쪽 하단에 있는 "작업 끝내기"를 클릭합니다.

Python으로 3D 지리 차트를 그리는 방법 개요: 3D 지리 차트를 그리는 것은 지리 데이터와 공간 분포를 보다 직관적으로 이해하는 데 도움이 될 수 있습니다. 강력하고 사용하기 쉬운 프로그래밍 언어인 Python은 다양한 유형의 지리 차트를 그리는 데 사용할 수 있는 많은 라이브러리와 도구를 제공합니다. 이 기사에서는 Python 프로그래밍 언어와 Matplotlib 및 Basemap과 같은 일부 인기 있는 라이브러리를 사용하여 3D 지리 차트를 그리는 방법을 알아봅니다. 환경 준비: 시작하기 전에 다음 사항을 확인해야 합니다.

많은 친구들이 컴퓨터를 사용할 때 특정 소프트웨어가 멈추는 현상을 경험합니다. 컴퓨터가 움직일 수 없으면 작업 관리자를 불러와 작업을 종료해야 합니다. 작업을 호출한 후 단축키를 사용하여 작업을 종료하는 방법이 가장 쉬운데, 다른 방법도 살펴보겠습니다. 아래를 살펴보세요. 작업 관리자에서 작업을 종료하기 위한 단축키를 사용하는 방법 작업 관리자에서 단축키를 사용하는 방법: 1. 키 조합 "Ctrl+Shift+ESC". 2. 키 조합 "Ctrl+Alt+Delete". 작업 종료 단축키 1. 종료할 작업을 선택하고 '삭제'를 클릭하세요. 2. 종료해야 하는 작업을 선택하고 "alt+e" 키 조합을 누르십시오.

Vue를 사용하여 3D 3차원 회전 효과를 얻는 방법 널리 사용되는 프런트 엔드 프레임워크인 Vue.js는 동적 웹 페이지 및 애플리케이션을 개발하는 데 중요한 역할을 합니다. 이는 대화형 인터페이스를 구축하는 직관적이고 효율적인 방법을 제공하며 통합 및 확장이 쉽습니다. 이 기사에서는 Vue.js를 사용하여 놀라운 3D 입체 회전 효과를 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 시작하기 전에 Vue.js가 설치되어 있는지 확인하고 Vue.js의 기본 사용법을 어느 정도 이해하고 있는지 확인하세요. 아직도

사무실에서 Tencent Meeting 소프트웨어를 자주 사용하시나요? 그렇다면 Tencent Meeting에서 회의를 종료하는 방법을 아시나요? 다음으로 편집자가 Tencent Meeting에서 회의를 종료하는 구체적인 방법을 알려드리겠습니다. 아래를 살펴보겠습니다. 컴퓨터를 켜고 두 번 클릭하여 Tencent Meeting에 입장한 다음 로그인하고 클릭하여 빠른 회의에 입장한 다음 회의 종료 버튼을 클릭합니다.

Vue와 Canvas를 사용하여 멋진 3D 회전 그래픽을 만드는 방법 소개: Vue와 Canvas는 각각 페이지 렌더링과 이미지 그리기를 처리하는 데 뛰어난 두 가지 매우 강력한 프런트 엔드 기술입니다. 이 기사에서는 Vue와 Canvas를 결합하여 멋진 3D 회전 그래픽 효과를 만드는 방법을 소개합니다. Vue를 사용하여 기본 페이지 구조를 구축하는 방법과 Canvas를 사용하여 3D 그래픽의 그리기 및 회전 효과를 얻는 방법을 살펴보겠습니다. 이 글을 공부하면 Vue와 Canvas를 활용하는 방법을 이해할 수 있을 것입니다.

Vue를 사용하여 3D 뒤집기 효과를 구현하는 방법 소개: Vue.js는 대화형 웹 애플리케이션을 구축하는 데 도움이 되는 인기 있는 JavaScript 프레임워크입니다. 이 기사에서는 Vue.js를 사용하여 멋진 3D 뒤집기 효과를 구현하는 방법을 살펴보고 참조용 특정 코드 예제를 제공합니다. 소개: 3D 뒤집기 효과는 웹사이트나 애플리케이션에 상호작용성과 매력을 더할 수 있습니다. 유연하고 사용하기 쉬운 프런트엔드 프레임워크인 Vue.js는 이를 쉽게 달성할 수 있습니다.
