AtCoder Beginner Contest 103
https://beta.atcoder.jp/contests/abc103
A - Task Scheduling Problem
Time Limit: 2 sec / Memory Limit: 1024 MB
Score : 100100 points
Problem Statement
You have three tasks, all of which need to be completed.
First, you can complete any one task at cost 00.
Then, just after completing the ii-th task, you can complete the jj-th task at cost |Aj−Ai||Aj−Ai|.
Here, |x||x| denotes the absolute value of xx.
Find the minimum total cost required to complete all the task.
Constraints
- All values in input are integers.
- 1≤A1,A2,A3≤1001≤A1,A2,A3≤100
Input
Input is given from Standard Input in the following format:
A1A1 A2A2 A3A3
Output
Print the minimum total cost required to complete all the task.
Sample Input 1 Copy
1 6 3
Sample Output 1 Copy
5
When the tasks are completed in the following order, the total cost will be 55, which is the minimum:
- Complete the first task at cost 00.
- Complete the third task at cost 22.
- Complete the second task at cost 33.
Sample Input 2 Copy
11 5 5
Sample Output 2 Copy
6
Sample Input 3 Copy
100 100 100
Sample Output 3 Copy
0 最大的减去最小的。
import java.util.Arrays;
import java.util.Scanner;
import static java.lang.Math.*;
public class Main { public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int [] a = new int[3];
for(int i = 0;i < 3;i ++) {
a[i] = in.nextInt();
}
Arrays.sort(a);
System.out.println(a[2] - a[0]);
}
}
B - String Rotation
Time Limit: 2 sec / Memory Limit: 1024 MB
Score : 200200 points
Problem Statement
You are given string SS and TT consisting of lowercase English letters.
Determine if SS equals TT after rotation.
That is, determine if SS equals TT after the following operation is performed some number of times:
Operation: Let S=S1S2...S|S|S=S1S2...S|S|. Change SS to S|S|S1S2...S|S|−1S|S|S1S2...S|S|−1.
Here, |X||X| denotes the length of the string XX.
Constraints
- 2≤|S|≤1002≤|S|≤100
- |S|=|T||S|=|T|
- SS and TT consist of lowercase English letters.
Input
Input is given from Standard Input in the following format:
SS
TT
Output
If SS equals TT after rotation, print Yes
; if it does not, print No
.
Sample Input 1 Copy
kyoto
tokyo
Sample Output 1 Copy
Yes
- In the first operation,
kyoto
becomesokyot
. - In the second operation,
okyot
becomestokyo
.
Sample Input 2 Copy
abc
arc
Sample Output 2 Copy
No
abc
does not equal arc
after any number of operations.
Sample Input 3 Copy
aaaaaaaaaaaaaaab
aaaaaaaaaaaaaaab
Sample Output 3 Copy
Yes
排着遍历拼接。
import java.util.Arrays;
import java.util.Scanner;
import static java.lang.Math.*;
public class Main {
static boolean check(String a,String b) {
if(a.length() != b.length())return false;
for(int i = 0;i < a.length();i ++) {
if(a.charAt(i) == b.charAt(0) && (a.substring(i, a.length()) + a.substring(0, i)).equals(b)) {
return true;
}
}
return false;
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String a = in.nextLine();
String b = in.nextLine();
System.out.println(check(a,b) ? "Yes" : "No");
}
}
C - Modulo Summation
Time Limit: 2 sec / Memory Limit: 1024 MB
Score : 300300 points
Problem Statement
You are given NN positive integers a1,a2,...,aNa1,a2,...,aN.
For a non-negative integer mm, let f(m)=(m mod a1)+(m mod a2)+...+(m mod aN)f(m)=(m mod a1)+(m mod a2)+...+(m mod aN).
Here, X mod YX mod Y denotes the remainder of the division of XX by YY.
Find the maximum value of ff.
Constraints
- All values in input are integers.
- 2≤N≤30002≤N≤3000
- 2≤ai≤1052≤ai≤105
Input
Input is given from Standard Input in the following format:
NN
a1a1 a2a2 ...... aNaN
Output
Print the maximum value of ff.
Sample Input 1 Copy
3
3 4 6
Sample Output 1 Copy
10
f(11)=(11 mod 3)+(11 mod 4)+(11 mod 6)=10f(11)=(11 mod 3)+(11 mod 4)+(11 mod 6)=10 is the maximum value of ff.
Sample Input 2 Copy
5
7 46 11 20 11
Sample Output 2 Copy
90
Sample Input 3 Copy
7
994 518 941 851 647 2 581
Sample Output 3 Copy
4527
一个数对多个数去摸和要最大。
对于m,m%a1最大值是a1 - 1,也就是说令m = t1 * a1 - 1(t1 >= 1)时m%a1最大,同样如果对于a1~n都满足m = ti * ai - 1,总和就会最大,实际上就是满足m = t1 * a1 - 1 = t2 * a2 - 1 = ...
= tn * an - 1,即t1 * a1 = t2 * a2 = ... = tn * an = m + 1,所以m + 1是a1~n的公倍数,是存在的。
答案就显而易见是所有属的和-n。
import java.util.Arrays;
import java.util.Scanner;
import static java.lang.Math.*;
public class Main {
static boolean check(String a,String b) {
if(a.length() != b.length())return false;
for(int i = 0;i < a.length();i ++) {
if(a.charAt(i) == b.charAt(0) && (a.substring(i, a.length()) + a.substring(0, i)).equals(b)) {
return true;
}
}
return false;
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int d;
int ans = -n;
for(int i = 0;i < n;i ++) {
d = in.nextInt();
ans += d;
}
System.out.println(ans);
}
}
D - Islands War
Time Limit: 2 sec / Memory Limit: 1024 MB
Score : 400400 points
Problem Statement
There are NN islands lining up from west to east, connected by N−1N−1 bridges.
The ii-th bridge connects the ii-th island from the west and the (i+1)(i+1)-th island from the west.
One day, disputes took place between some islands, and there were MM requests from the inhabitants of the islands:
Request ii: A dispute took place between the aiai-th island from the west and the bibi-th island from the west. Please make traveling between these islands with bridges impossible.
You decided to remove some bridges to meet all these MM requests.
Find the minimum number of bridges that must be removed.
Constraints
- All values in input are integers.
- 2≤N≤1052≤N≤105
- 1≤M≤1051≤M≤105
- 1≤ai<bi≤N1≤ai<bi≤N
- All pairs (ai,bi)(ai,bi) are distinct.
Input
Input is given from Standard Input in the following format:
NN MM
a1a1 b1b1
a2a2 b2b2
::
aMaM bMbM
Output
Print the minimum number of bridges that must be removed.
Sample Input 1 Copy
5 2
1 4
2 5
Sample Output 1 Copy
1
The requests can be met by removing the bridge connecting the second and third islands from the west.
Sample Input 2 Copy
9 5
1 8
2 7
3 5
4 6
7 9
Sample Output 2 Copy
2
Sample Input 3 Copy
5 10
1 2
1 3
1 4
1 5
2 3
2 4
2 5
3 4
3 5
4 5
Sample Output 3 Copy
4
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
import static java.lang.Math.*;
class bridge{
public int a;
public int b;
public bridge() {
a = b = 0;
}
}
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int k = in.nextInt();
bridge [] s = new bridge[k];
for(int i = 0;i < k;i ++) {
s[i] = new bridge();
s[i].a = in.nextInt();
s[i].b = in.nextInt();
}
Arrays.sort(s,new Comparator<bridge>() {
public int compare(bridge x,bridge y) {
if(x.a == x.b)return x.b - y.b;
return x.a - y.a;
}
});
int ans = 0,r = 0;
for(int i = 0;i < k;i ++) {
if(s[i].a >= r) {
ans ++;
r = s[i].b;
}
else if(r > s[i].b)r = s[i].b;
}
System.out.println(ans);
}
}
AtCoder Beginner Contest 103的更多相关文章
- AtCoder Beginner Contest 100 2018/06/16
A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...
- AtCoder Beginner Contest 052
没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...
- AtCoder Beginner Contest 053 ABCD题
A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...
- AtCoder Beginner Contest 136
AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...
- AtCoder Beginner Contest 137 F
AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...
- AtCoder Beginner Contest 076
A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...
- AtCoder Beginner Contest 079 D - Wall【Warshall Floyd algorithm】
AtCoder Beginner Contest 079 D - Wall Warshall Floyd 最短路....先枚举 k #include<iostream> #include& ...
- AtCoder Beginner Contest 064 D - Insertion
AtCoder Beginner Contest 064 D - Insertion Problem Statement You are given a string S of length N co ...
- AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle【暴力】
AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle 我要崩溃,当时还以为是需要什么离散化的,原来是暴力,特么五层循环....我自己写怎么都 ...
随机推荐
- 安装gi的时候回退root.sh的运行
</pre><pre name="code" class="html">/u01/app/11.2.0/grid/crs/install ...
- 配置fio支持rbd測试引擎
fio的rbd測试引擎能够非常方便的对rbd进行測试.以下示范怎样安装fio支持rbd引擎. git clone git://git.kernel.dk/fio.git $ cd fio $ ./co ...
- ALLEGRO修改位号回注ORCAD原理图
资料:ALLEGRO修改位号回注ORCAD原理图 https://wenku.baidu.com/view/54e221e114791711cd7917e2.html?re=view
- Spring学习九----------Bean的配置之Bean的定义及作用域的注解实现
© 版权声明:本文为博主原创文章,转载请注明出处 Spring Bean常用注解 @Component:通常注解,可用于任何Bean @Repository:通常用于注解DAO层,即持久层 @Serv ...
- typedef struct与struct定义结构体
今天在定义结构体的时候发现typedef struct与struct定义结构体有一些不同之处: 结构也是一种数据类型, 能够使用结构变量, 因此, 象其他 类型的变量一样, 在使用结构变量时要先对其 ...
- FTPHelper类
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.N ...
- 现在有一个城市销售经理,需要从公司出发,去拜访市内的商家,已知他的位置以及商家的位置,但是由于城市道路交通的原因,他只能在左右中选择一个方向,在上下中选择一个方向,现在问他有多少种方案到达商家地址。给定一个地图map及它的长宽n和m,其中1代表经理位置,2代表商家位置,-1代表不能经过的地区,0代表可以经过的地区,请返回方案数,保证一定存在合法路径。保证矩阵的长宽都小于等于10。
include "stdafx.h" #include<iostream> #include<vector> #include<algorithm&g ...
- JS之字符串与JSON转换
JS之字符串转换JSON 1.eval 古老的方式 function strToJson(str){ var json = eval('(' + str + ')'); return json; ...
- java常量池概念 (转)
在class文件中,“常量池”是最复杂也最值得关注的内容. Java是一种动态连接的语言,常量池的作用非常重要,常量池中除了包含代码中所定义的各种基本类型(如int.long等等)和对象型(如Stri ...
- 利用socket.io实现多人聊天室(基于Nodejs)
socket.io简单介绍 在Html5中存在着这种一个新特性.引入了websocket,关于websocket的内部实现原理能够看这篇文章.这篇文章讲述了websocket无到有,依据协议,分析数据 ...