Home Web Front-end HTML Tutorial BestCoder Round #11 (Div. 2)Problem solution collection_html/css_WEB-ITnose

BestCoder Round #11 (Div. 2)Problem solution collection_html/css_WEB-ITnose

Jun 24, 2016 am 11:57 AM
round gather

Alice and Bob Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 155    Accepted Submission(s): 110


Problem Description

Bob and Alice got separated in the Square, they agreed that if they get separated, they'll meet back at the coordinate point (x, y). Unfortunately they forgot to define the origin of coordinates and the coordinate axis direction. Now, Bob in the lower left corner of the Square, Alice in the upper right corner of the the Square. Bob regards the lower left corner as the origin of coordinates, rightward for positive direction of axis X, upward for positive direction of axis Y. Alice regards the upper right corner as the origin of coordinates, leftward for positive direction of axis X, downward for positive direction of axis Y. Assuming that Square is a rectangular, length and width size is N * M. As shown in the figure:

Bob and Alice with their own definition of the coordinate system respectively, went to the coordinate point (x, y). Can they meet with each other ?
Note: Bob and Alice before reaching its destination, can not see each other because of some factors (such as buildings, time poor).

 


Input

There are multiple test cases. Please process till EOF. Each test case only contains four integers : N, M and x, y. The Square size is N * M, and meet in coordinate point (x, y). ( 0 < x < N <= 1000 , 0 < y < M <= 1000 ).

 


Output

If they can meet with each other, please output "YES". Otherwise, please output "NO".

 


Sample Input

              <p class="sycode">                  10 10 5 510 10 6 6              </p>
Copy after login

 


Sample Output

              <p class="sycode">                  YESNO              </p>
Copy after login

 


Source

BestCoder Round #11 (Div. 2)

 


Recommend

heyang   |   We have carefully selected several similar problems for you:   5053  5052  5051  5050  5049 

  题意:

给一个矩形区域告诉你它的长和宽。然后两个坐标系。一个为左下角为原点。右上为正方向。一个右上角为原点。右下为正方向。现在给你一个坐标(x,y)问你在两种坐标系中他们是不是表示同一个点。

思路:

把不同的坐标系转换到同一坐标系就行了。我是把左上角转换到右下角的。

详细见代码:

#include<algorithm>#include<iostream>#include<string.h>#include<stdio.h>using namespace std;const int INF=0x3f3f3f3f;const int maxn=100010;typedef long long ll;int main(){    int n,m,x,y;    while(~scanf("%d%d%d%d",&n,&m,&x,&y))    {        if(x==n-x&&y==m-y)            printf("YES\n");        else            printf("NO\n");    }    return 0;}   <br>   </p>
<p class="sycode">    Bob and math problem    <strong>Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)<br> Total Submission(s): 456    Accepted Submission(s): 169<br> </strong>    <br>    <br>    </p>
<p class="sycode">     Problem Description    </p>    <p class="sycode">     Recently, Bob has been thinking about a math problem.     <br> There are N Digits, each digit is between 0 and 9. You need to use this N Digits to constitute an Integer.     <br> This Integer needs to satisfy the following conditions:     <br>     </p>
<li>1. must be an odd Integer.<br> </li>     <li>2. there is no leading zero.<br> </li>     <li>3. find the biggest one which is satisfied 1, 2.</li>     <br> Example:     <br> There are three Digits: 0, 1, 3. It can constitute six number of Integers. Only "301", "103" is legal, while "130", "310", "013", "031" is illegal. The biggest one of odd Integer is "301".        <p class="sycode">          </p>    <br>    <p class="sycode">     Input    </p>    <p class="sycode">     There are multiple test cases. Please process till EOF.     <br> Each case starts with a line containing an integer N ( 1 <= N <= 100 ).     <br /> The second line contains N Digits which indicate the digit $a_1, a_2, a_3, cdots, a_n. ( 0 leq a_i leq 9)$.    </p>    <p class="sycode">          </p>    <br />    <p class="sycode">     Output    </p>    <p class="sycode">     The output of each test case of a line. If you can constitute an Integer which is satisfied above conditions, please output the biggest one. Otherwise, output "-1" instead.    </p>    <p class="sycode">          </p>    <br />    <p class="sycode">     Sample Input    </p>    <p class="sycode">     <pre class="brush:php;toolbar:false">                      <p class="sycode">                          30 1 335 4 232 4 6                      </p>
Copy after login


Sample Output

                      <p class="sycode">                          301425-1                      </p>
Copy after login


Source

BestCoder Round #11 (Div. 2)


Recommend

heyang | We have carefully selected several similar problems for you: 5053 5052 5051 5050 5049

题意:

给你n个数字要你组成 n位数的最大的一个奇数。不行就输出-1.

思路:

开始读错题意了。以为输出的不一定要用到所有数字。于是判完后就挂了。真搞不懂怎么过开始的数据的。。。

这题贪心构造就行了。先找一个最小的奇数来做个位如果没有的话就-1。然后把剩下的数排序。如果剩下的还有数字且最大的为0的话肯定输出-1了。不是的话就按降序输出在加上那会找的奇数就行了。

详细见代码:

#include<algorithm>#include<iostream>#include<string.h>#include<stdio.h>using namespace std;const int INF=0x3f3f3f3f;const int maxn=100010;typedef long long ll;int arr[150],brr[150];int main(){    int n,i,p,ct;    while(~scanf("%d",&n))    {        ct=0,p=-1;        for(i=0;i<n;i++)        {            scanf("%d",&arr[i]);            if(arr[i]&1)            {                if(p==-1||arr[i]<arr[p])                    p=i;            }        }        if(p==-1)        {            printf("-1\n");            continue;        }        for(i=0;i<n;i++)            if(i!=p)                brr[ct++]=arr[i];        sort(brr,brr+ct);        if(ct&&brr[ct-1]==0)        {            printf("-1\n");            continue;        }        for(i=ct-1;i>=0;i--)            printf("%d",brr[i]);        printf("%d\n",arr[p]);    }    return 0;}    <br> Boring count    <strong>Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)<br> Total Submission(s): 250    Accepted Submission(s): 98<br> </strong>    <br>    <br>    </p>
<p class="sycode">     Problem Description    </p>    <p class="sycode">     You are given a string S consisting of lowercase letters, and your task is counting the number of substring that the number of each lowercase letter in the substring is no more than K.    </p>    <p class="sycode">          </p>    <br>    <p class="sycode">     Input    </p>    <p class="sycode">     In the first line there is an integer T , indicates the number of test cases.     <br> For each case, the first line contains a string which only consist of lowercase letters. The second line contains an integer K.     <br>     <br> [Technical Specification]     <br> 1<=T<= 100     <br /> 1 <= the length of S <= 100000     <br /> 1 <= K <= 100000    </p>    <p class="sycode">          </p>    <br />    <p class="sycode">     Output    </p>    <p class="sycode">     For each case, output a line contains the answer.    </p>    <p class="sycode">          </p>    <br />    <p class="sycode">     Sample Input    </p>    <p class="sycode">     <pre class="brush:php;toolbar:false">                      <p class="sycode">                          3abc1abcabc1abcabc2                      </p>
Copy after login


Sample Output

                      <p class="sycode">                          61521                      </p>
Copy after login


Source

BestCoder Round #11 (Div. 2)


Recommend

heyang | We have carefully selected several similar problems for you: 5053 5052 5051 5050 5049

题意:

给你一个长度不超过1e5由小写组成的字符串。问你它有多少个子串。满足子串的每个字符出现的次数都不超过k。

思路:

对于一个满足条件的左端点le。把右端点ri的字符一个一个的加进去。如果还是满足条件。这个新加进的字符将会贡献ri-le+1个以该子符为右端点的子串。如果不满足条件了就左移le指针知道满足条件即可。比赛时早就想到思路了。可各种逻辑错误1小时+才1A。

详细见代码:

#include<algorithm>#include<iostream>#include<string.h>#include<stdio.h>using namespace std;const int INF=0x3f3f3f3f;const int maxn=100002;typedef long long ll;char txt[maxn];int vis[27];ll ans=0;int main(){    int t,n,k,le,ri,p;    scanf("%d",&t);    while(t--)    {        scanf("%s%d",txt,&k);        n=strlen(txt);        ans=le=ri=0;        memset(vis,0,sizeof vis);        p=-1;        while(ri<=n)        {            if(p==-1)            {                vis[txt[ri]-'a']++;                if(vis[txt[ri]-'a']>k)                    p=ri;                else if(ri<n)                    ans+=ri-le+1;                ri++;            }            else            {                vis[txt[le]-'a']--;                if(txt[le]==txt[p])                    p=-1,ans+=ri-le-1;                le++;            }        }        printf("%I64d\n",ans);    }    return 0;}
Copy after login

Argestes and Sequence Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 192 Accepted Submission(s): 44


Problem Description

Argestes has a lot of hobbies and likes solving query problems especially. One day Argestes came up with such a problem. You are given a sequence a consisting of N nonnegative integers, a[1],a[2],...,a[n].Then there are M operation on the sequence.An operation can be one of the following:
S X Y: you should set the value of a[x] to y(in other words perform an assignment a[x]=y).
Q L R D P: among [L, R], L and R are the index of the sequence, how many numbers that the Dth digit of the numbers is P.
Note: The 1st digit of a number is the least significant digit.


Input

In the first line there is an integer T , indicates the number of test cases.
For each case, the first line contains two numbers N and M.The second line contains N integers, separated by space: a[1],a[2],...,a[n]?initial value of array elements.
Each of the next M lines begins with a character type.
If type==S,there will be two integers more in the line: X,Y.
If type==Q,there will be four integers more in the line: L R D P.

[Technical Specification]
1<=T<= 50
1<=N, M<=100000
0<=a[i]<=$2^{31}$ - 1
1<=X<=N
0<=Y<=$2^{31}$ - 1
1<=L<=R<=N
1<=D<=10
0<=P<=9


Output

For each operation Q, output a line contains the answer.


Sample Input

                      <p class="sycode">                          15 710 11 12 13 14Q 1 5 2 1Q 1 5 1 0Q 1 5 1 1Q 1 5 3 0Q 1 5 3 1S 1 100Q 1 5 3 1                      </p>
Copy after login


Sample Output

                      <p class="sycode">                          511501                      </p>
Copy after login


Source

BestCoder Round #11 (Div. 2)


Recommend

heyang | We have carefully selected several similar problems for you: 5053 5052 5051 5050 5049

题意:

给你一个长度不超过1e5的数列。你可以进行两种操作。

1.S x y。把第x个数变成y。

2.Q l r d p 。询问[l,r]中数的第d个数字是p的有多少个。

思路:
看到这题。喜出望外。今天是可以ak的节奏啊。(不知道1002会挂。。--||)。感觉典型线段树的应用。每个节点一个数组val[rt][i][j]。表示节点代表的区间里第i个数字为j的有多少个。然后欢快的写完了。写完编译运行一次通过。无任何错误和警告测样例完全正确!然后愉快的交了。然后就mle了。。。当时就傻了。一看题目内存限制。晕。居然有数据结构题目卡内存的。然后想了下树状数组开1e7空间就算是short也超了,但是想到了离线处理每一位的修改和询问。但这时已经20:20。依稀的记得20:30就要开hack了。就放弃了挣扎了。后来醒悟后还是没时间改了。虽然正解有我说的离线处理。但是总觉得还是蛮麻烦的就用分块写了。就是分成sqrt(n)块。块内直接暴力。块间利用整块信息维护快速算出答案。时间复杂度O(n*sqrt(n))。写完一交居然rank1.估计O(10*n*log(n))的做法常数太大了。

详细见代码:

#include#include#include#include#includeusing namespace std;const int INF=0x3f3f3f3f;const int maxn=100003;typedef long long ll;#define lson L,mid,ls#define rson mid+1,R,rsint val[maxn][11],da[400][11][10],x;int main(){    int t,n,m,i,j,le,ri,d,p,x,y,bk,ans,st,ed,lim;    char cmd[10];    scanf("%d",&t);    while(t--)    {        scanf("%d%d",&n,&m);        bk=ceil(sqrt(1.0*n));        memset(da,0,sizeof da);        memset(val,0,sizeof val);        for(i=1;i<=n;i++)        {            scanf("%d",&x);            for(j=1;j<=10;j++)            {                val[i][j]=x%10;                x/=10;            }            p=(i-1)/bk;            for(j=1;j<=10;j++)                da[p][j][val[i][j]]++;        }        for(i=0;i    

Statement of this Website
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

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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Why is it difficult to implement collection-like functions in Go language? Why is it difficult to implement collection-like functions in Go language? Mar 24, 2024 am 11:57 AM

It is difficult to implement collection-like functions in the Go language, which is a problem that troubles many developers. Compared with other programming languages ​​such as Python or Java, the Go language does not have built-in collection types, such as set, map, etc., which brings some challenges to developers when implementing collection functions. First, let's take a look at why it is difficult to implement collection-like functionality directly in the Go language. In the Go language, the most commonly used data structures are slice and map. They can complete collection-like functions, but

How to optimize Java collection sorting performance How to optimize Java collection sorting performance Jun 30, 2023 am 10:43 AM

Java is a powerful programming language that is widely used in various types of software development. In Java development, scenarios that often involve sorting collections are involved. However, if performance optimization is not performed for collection sorting, the execution efficiency of the program may decrease. This article will explore how to optimize the performance of Java collection sorting. 1. Choose the appropriate collection class In Java, there are many collection classes that can be used for sorting, such as ArrayList, LinkedList, TreeSet, etc. Different collection classes are in

What does round mean in php What does round mean in php Mar 10, 2023 am 10:04 AM

In PHP, round means "rounding" and is a built-in function that converts floating point numbers into integers. This function can round floating point numbers and return an integer value of type float. The syntax is "round(number, precision,mode);".

A Practical Guide to the Where Method in Laravel Collections A Practical Guide to the Where Method in Laravel Collections Mar 10, 2024 pm 04:36 PM

Practical Guide to Where Method in Laravel Collections During the development of the Laravel framework, collections are a very useful data structure that provide rich methods to manipulate data. Among them, the Where method is a commonly used filtering method that can filter elements in a collection based on specified conditions. This article will introduce the use of the Where method in Laravel collections and demonstrate its usage through specific code examples. 1. Basic usage of Where method

How to divide and round using PHP's round() function How to divide and round using PHP's round() function Mar 21, 2023 pm 04:32 PM

The round() function is a very useful function in the PHP number formatting library, which can round floating point numbers to a specified number of decimal places. However, since PHP's division operation may suffer from infinite decimals or loss of precision, rounding of the divisor is also necessary. Next, we will explain in detail how to use PHP's round() function to divide and round.

Common concurrent collections and thread safety issues in C# Common concurrent collections and thread safety issues in C# Oct 09, 2023 pm 10:49 PM

Common concurrent collections and thread safety issues in C# In C# programming, handling concurrent operations is a very common requirement. Thread safety issues arise when multiple threads access and modify the same data at the same time. In order to solve this problem, C# provides some concurrent collection and thread safety mechanisms. This article will introduce common concurrent collections in C# and how to deal with thread safety issues, and give specific code examples. Concurrent collection 1.1ConcurrentDictionaryConcurrentDictio

Add all elements from one collection to another using the addAll() method of the HashSet class Add all elements from one collection to another using the addAll() method of the HashSet class Jul 24, 2023 am 08:58 AM

Use the addAll() method of the HashSet class to add all elements in a collection to another collection. HashSet is an implementation class in the Java collection framework. It inherits from AbstractSet and implements the Set interface. HashSet is an unordered set based on a hash table, which does not allow duplicate elements. It provides many commonly used methods to operate elements in the collection, one of which is the addAll() method. The function of the addAll() method is to add the specified

Java Iterator vs. Iterable: A step into writing elegant code Java Iterator vs. Iterable: A step into writing elegant code Feb 19, 2024 pm 02:54 PM

Iterator interface The Iterator interface is an interface used to traverse collections. It provides several methods, including hasNext(), next() and remove(). The hasNext() method returns a Boolean value indicating whether there is a next element in the collection. The next() method returns the next element in the collection and removes it from the collection. The remove() method removes the current element from the collection. The following code example demonstrates how to use the Iterator interface to iterate over a collection: Listnames=Arrays.asList("John","Mary","Bob");Iterator

See all articles