题目链接
A. Poster
time limit per test:1 second
memory limit per test:256 megabytes
input:standard input
output:standard output
The R1 company has recently bought a high rise building in the centre of Moscow for its main office. It's time to decorate the new office, and the first thing to do is to write the company's slogan above the main entrance to the building.
The slogan of the company consists of n characters, so the decorators hung a large banner, n meters wide and 1 meter high, divided into n equal squares. The first character of the slogan must be in the first square (the leftmost) of the poster, the second character must be in the second square, and so on.
Of course, the R1 programmers want to write the slogan on the poster themselves. To do this, they have a large (and a very heavy) ladder which was put exactly opposite the k-th square of the poster. To draw the i-th character of the slogan on the poster, you need to climb the ladder, standing in front of the i-th square of the poster. This action (along with climbing up and down the ladder) takes one hour for a painter. The painter is not allowed to draw characters in the adjacent squares when the ladder is in front of the i-th square because the uncomfortable position of the ladder may make the characters untidy. Besides, the programmers can move the ladder. In one hour, they can move the ladder either a meter to the right or a meter to the left.
Drawing characters and moving the ladder is very tiring, so the programmers want to finish the job in as little time as possible. Develop for them an optimal poster painting plan!
The first line contains two integers, n and k (1 ≤ k ≤ n ≤ 100) — the number of characters in the slogan and the initial position of the ladder, correspondingly. The next line contains the slogan as n characters written without spaces. Each character of the slogan is either a large English letter, or digit, or one of the characters: '.', '!', ',', '?'.
In t lines, print the actions the programmers need to make. In the i-th line print:
- "LEFT" (without the quotes), if the i-th action was "move the ladder to the left";
- "RIGHT" (without the quotes), if the i-th action was "move the ladder to the right";
- "PRINT x" (without the quotes), if the i-th action was to "go up the ladder, paint character x, go down the ladder".
The painting time (variable t) must be minimum possible. If there are multiple optimal painting plans, you can print any of them.
2 2
R1
PRINT 1
LEFT
PRINT R
2 1
R1
PRINT R
RIGHT
PRINT 1
6 4
GO?GO!
RIGHT
RIGHT
PRINT !
LEFT
PRINT O
LEFT
PRINT G
LEFT
PRINT ?
LEFT
PRINT O
LEFT
PRINT G
Note that the ladder cannot be shifted by less than one meter. The ladder can only stand in front of some square of the poster. For example, you cannot shift a ladder by half a meter and position it between two squares. Then go up and paint the first character and the second character.
题意 : 一块标题,每次只能刷一个字,问你最少多少时间能刷完,要怎么刷才行。
思路 : 靠近哪边就往哪边刷。
1 #include2 #include <string.h> 3 #include 4 5 using namespace std ; 6 7 char ch[110] ; 8 9 int main() 10 { 11 int n ,k ; 12 while(~scanf("%d %d",&n,&k)) 13 { 14 scanf("%s",ch) ; 15 if(k == n) 16 { 17 printf("PRINT %c\n",ch[n-1]) ; 18 for(int i = n-2 ; i >= 0 ; i--) 19 { 20 printf("LEFT\n") ; 21 printf("PRINT %c\n",ch[i]) ; 22 } 23 } 24 else if(k == 1) 25 { 26 printf("PRINT %c\n",ch[0]) ; 27 for(int i = 1 ; i < n ; i++) 28 { 29 printf("RIGHT\n") ; 30 printf("PRINT %c\n",ch[i]) ; 31 } 32 } 33 else 34 { 35 if(n-k <= k-1) 36 { 37 for(int i = k+1 ; i <= n ; i++) 38 printf("RIGHT\n") ; 39 printf("PRINT %c\n",ch[n-1]) ; 40 for(int i = n-2 ; i >= 0 ; i --) 41 { 42 printf("LEFT\n") ; 43 printf("PRINT %c\n",ch[i]) ; 44 } 45 } 46 else 47 { 48 for(int i = 1 ; i < k ; i++) 49 printf("LEFT\n") ; 50 printf("PRINT %c\n",ch[0]) ; 51 for(int i = 1 ; i < n ; i++) 52 { 53 printf("RIGHT\n") ; 54 printf("PRINT %c\n",ch[i]) ; 55 } 56 } 57 } 58 } 59 return 0 ; 60 }
B. Network Configuration
time limit per test:1 second
memory limit per test:256 megabytes
input:standard input
output:standard output
The R1 company wants to hold a web search championship. There were n computers given for the competition, each of them is connected to the Internet. The organizers believe that the data transfer speed directly affects the result. The higher the speed of the Internet is, the faster the participant will find the necessary information. Therefore, before the competition started, each computer had its maximum possible data transfer speed measured. On the i-th computer it was ai kilobits per second.
There will be k participants competing in the championship, each should get a separate computer. The organizing company does not want any of the participants to have an advantage over the others, so they want to provide the same data transfer speed to each participant's computer. Also, the organizers want to create the most comfortable conditions for the participants, so the data transfer speed on the participants' computers should be as large as possible.
The network settings of the R1 company has a special option that lets you to cut the initial maximum data transfer speed of any computer to any lower speed. How should the R1 company configure the network using the described option so that at least k of n computers had the same data transfer speed and the data transfer speed on these computers was as large as possible?
The first line contains two space-separated integers n and k (1 ≤ k ≤ n ≤ 100) — the number of computers and the number of participants, respectively. In the second line you have a space-separated sequence consisting of n integers: a1, a2, ..., an (16 ≤ ai ≤ 32768); number ai denotes the maximum data transfer speed on the i-th computer.
Print a single integer — the maximum Internet speed value. It is guaranteed that the answer to the problem is always an integer.
3 2
40 20 30
30
6 4
100 20 40 20 50 50
40
In the first test case the organizers can cut the first computer's speed to 30 kilobits. Then two computers (the first and the third one) will have the same speed of 30 kilobits. They should be used as the participants' computers. This answer is optimal.
题意 : 给你n个网速,大网速可以切成任意的比它小的网速,让你输出能得到的最大的k个网速是多大。
思路 : 其实就是求第k大的数是多少。
1 //B 2 #include3 #include <string.h> 4 #include 5 #include 6 7 using namespace std ; 8 9 int a[110] ; 10 11 int main() 12 { 13 int n,k ; 14 while(~scanf("%d %d",&n,&k)) 15 { 16 for(int i = 0 ; i < n ; i++) 17 scanf("%d",&a[i]) ; 18 sort(a,a+n) ; 19 printf("%d\n",a[n-k]) ; 20 } 21 return 0 ; 22 }
C. Pattern
time limit per test:1 second
memory limit per test:256 megabytes
input:standard input
output:standard output
Developers often face with regular expression patterns. A pattern is usually defined as a string consisting of characters and metacharacters that sets the rules for your search. These patterns are most often used to check whether a particular string meets the certain rules.
In this task, a pattern will be a string consisting of small English letters and question marks ('?'). The question mark in the pattern is a metacharacter that denotes an arbitrary small letter of the English alphabet. We will assume that a string matches the pattern if we can transform the string into the pattern by replacing the question marks by the appropriate characters. For example, string aba matches patterns: ???, ??a, a?a, aba.
Programmers that work for the R1 company love puzzling each other (and themselves) with riddles. One of them is as follows: you are given n patterns of the same length, you need to find a pattern that contains as few question marks as possible, and intersects with each of the given patterns. Two patterns intersect if there is a string that matches both the first and the second pattern. Can you solve this riddle?
The first line contains a single integer n (1 ≤ n ≤ 105) — the number of patterns. Next n lines contain the patterns.
It is guaranteed that the patterns can only consist of small English letters and symbols '?'. All patterns are non-empty and have the same length. The total length of all the patterns does not exceed 105 characters.
In a single line print the answer to the problem — the pattern with the minimal number of signs '?', which intersects with each of the given ones. If there are several answers, print any of them.
2
?ab
??b
xab
2
a
b
?
1
?a?b
cacb
Consider the first example. Pattern xab intersects with each of the given patterns. Pattern ??? also intersects with each of the given patterns, but it contains more question signs, hence it is not an optimal answer. Clearly, xab is the optimal answer, because it doesn't contain any question sign. There are a lot of other optimal answers, for example: aab, bab, cab, dab and so on.
题意 : 其实一开始我没怎么看懂题意,搜了题解才懂题意,就是给你n个长度相同的字符串,让你找一个能匹配所有字符串的尽量用较少的‘?’的字符串输出,因为问号可以看为随意的字母。
思路 :找每一列,如果都是问号的话就换成随意一个小写字母都行(我用的是a),如果这一列只有一个字母,那么就是这个字母,如果这一列不仅有问号还有别的英文字母而且这些英文字母都是一个,那还是换成这个字母,如果这一列有两个不同的字母,就只能用问号匹配了。
1 //C 2 #include3 #include <string.h> 4 #include 5 6 using namespace std ; 7 8 char ch[105000],sh[105000] ; 9 int flag[105000] ; 10 11 int main() 12 { 13 int n ,len; 14 scanf("%d",&n) ; 15 for(int i = 0 ; i < 105000 ; i++) 16 sh[i] = '?' ; 17 memset(flag,0,sizeof(flag)) ; 18 for(int i = 0 ; i < n ; i++) 19 { 20 scanf("%s",ch) ; 21 len = strlen(ch) ; 22 for(int j = 0 ; j < len ; j++) 23 { 24 if( !flag[j] && sh[j] == '?') 25 sh[j] = ch[j] ; 26 else if(ch[j] == '?') continue ; 27 else if(sh[j] == ch[j]) 28 { 29 continue ; 30 } 31 else if( !flag[j] && sh[j] != ch[j] && ch[j] != '?' && sh[j] != '?') 32 { 33 flag[j] = 1 ; 34 sh[j] = '?' ; 35 } 36 } 37 // printf("*%c*\n",sh[len-1]) ; 38 } 39 for(int i = 0 ; i < len ; i++) 40 { 41 if(flag[i] && sh[i] == '?') 42 printf("?") ; 43 else if(!flag[i] && sh[i] == '?') 44 printf("a") ; 45 else printf("%c",sh[i]) ; 46 } 47 return 0 ; 48 }
D. Giving Awards
time limit per test:1 second
memory limit per test:256 megabytes
input:standard input
output:standard output
The employees of the R1 company often spend time together: they watch football, they go camping, they solve contests. So, it's no big deal that sometimes someone pays for someone else.
Today is the day of giving out money rewards. The R1 company CEO will invite employees into his office one by one, rewarding each one for the hard work this month. The CEO knows who owes money to whom. And he also understands that if he invites person x to his office for a reward, and then immediately invite person y, who has lent some money to person x, then they can meet. Of course, in such a situation, the joy of person x from his brand new money reward will be much less. Therefore, the R1 CEO decided to invite the staff in such an order that the described situation will not happen for any pair of employees invited one after another.
However, there are a lot of employees in the company, and the CEO doesn't have a lot of time. Therefore, the task has been assigned to you. Given the debt relationships between all the employees, determine in which order they should be invited to the office of the R1 company CEO, or determine that the described order does not exist.
The first line contains space-separated integers n and m — the number of employees in R1 and the number of debt relations. Each of the following m lines contains two space-separated integers ai, bi (1 ≤ ai, bi ≤ n; ai ≠ bi), these integers indicate that the person number ai owes money to a person a number bi. Assume that all the employees are numbered from 1 to n.
It is guaranteed that each pair of people p, q is mentioned in the input data at most once. In particular, the input data will not contain pairs p, q and q, p simultaneously.
Print -1 if the described order does not exist. Otherwise, print the permutation of n distinct integers. The first number should denote the number of the person who goes to the CEO office first, the second number denote the person who goes second and so on.
If there are multiple correct orders, you are allowed to print any of them.
2 1
1 2
2 1
3 3
1 2
2 3
3 1
题意:老板要发工资,如果1欠了2的钱,那么发工资的时候,先叫1进去给他工资,然后再叫2进去的话,那1肯定就不会那么高兴了,所以老板发工资的时候要杜绝这种情况,让你输出一个合理的序列,如果不能就输出-1 .
1 //D 2 #include3 #include <string.h> 4 #include 5 #include 6 7 using namespace std ; 8 9 bool vis[30101] ; 10 int a ; 11 int n,m ; 12 vector<int> v[30101] ; 13 14 void DFS(int u) 15 { 16 if(vis[u]) return ; 17 vis[u] = true ; 18 for(int i = 0 ; i < v[u].size() ; i++) 19 { 20 DFS(v[u][i]) ; 21 } 22 a++ ; 23 if(a == n) 24 printf("%d\n",u) ; 25 else printf("%d ",u) ; 26 } 27 int main() 28 { 29 int c,d ; 30 while(~scanf("%d %d",&n,&m)) 31 { 32 memset(vis,false ,sizeof(vis)) ; 33 for(int i = 1 ; i <= n ; i++) 34 v[i].clear() ; 35 while(m -- ) 36 { 37 scanf("%d %d",&c,&d) ; 38 v[c].push_back(d) ; 39 } 40 a = 0 ; 41 for(int i = 1 ; i <= n ; i++) 42 { 43 if(!vis[i]) 44 DFS(i) ; 45 } 46 } 47 return 0 ; 48 }
E. E-mail Addresses
time limit per test:1 second
memory limit per test:256 megabytes
input:standard input
output:standard output
One of the most important products of the R1 company is a popular @r1.com mail service. The R1 mailboxes receive and send millions of emails every day.
Today, the online news thundered with terrible information. The R1 database crashed and almost no data could be saved except for one big string. The developers assume that the string contains the letters of some users of the R1 mail. Recovering letters is a tedious mostly manual work. So before you start this process, it was decided to estimate the difficulty of recovering. Namely, we need to calculate the number of different substrings of the saved string that form correct e-mail addresses.
We assume that valid addresses are only the e-mail addresses which meet the following criteria:
- the address should begin with a non-empty sequence of letters, numbers, characters '_', starting with a letter;
- then must go character '@';
- then must go a non-empty sequence of letters or numbers;
- then must go character '.';
- the address must end with a non-empty sequence of letters.
You got lucky again and the job was entrusted to you! Please note that the substring is several consecutive characters in a string. Two substrings, one consisting of the characters of the string with numbers l1, l1 + 1, l1 + 2, ..., r1 and the other one consisting of the characters of the string with numbers l2, l2 + 1, l2 + 2, ..., r2, are considered distinct if l1 ≠ l2 or r1 ≠ r2.
The first and the only line contains the sequence of characters s1s2... sn (1 ≤ n ≤ 106) — the saved string. It is guaranteed that the given string contains only small English letters, digits and characters '.', '_', '@'.
Print in a single line the number of substrings that are valid e-mail addresses.
[email protected]
18
8
[email protected]
1
.asd123__..@
0
In the first test case all the substrings that are correct e-mail addresses begin from one of the letters of the word agapov and end in one of the letters of the word com.
In the second test case note that the e-mail [email protected] is considered twice in the answer. Note that in this example the e-mail entries overlap inside the string.
题意 : 一个合格的电子邮箱必须满足一下条件:
- 邮箱的前边必须是一个非空的序列,必须是字母数字或者是下划线,特别的,第一个字符必须是字母。
- 然后接下来必须是字符@
- 然后接下来必须是非空的字符串,由字母和数字组成。
- 接下来必须是字符 .
- 最后必须是非空的字符串由字母组成。
然后给你一个字符串让你求里边有多少个符合标准的电子邮箱。
思路 : 其实先找@前边的字符,找有多少个字母,然后找 . 后边有多少个字母相乘,这个我看的题解,自己写的时候指针都指乱了,由此看出自己和别人的差距啊!
1 #include2 #include <string.h> 3 #include 4 5 using namespace std ; 6 7 char ch[1052001] ; 8 9 int main() 10 { 11 scanf("%s",ch) ; 12 int len = strlen(ch) ; 13 long long cnt = 0 ,a = 0,ans = 0 ; 14 for(int i = 0 ; i < len ; i++) 15 { 16 if((ch[i] >= 'a' && ch[i] <= 'z')) cnt ++ ; 17 else if(ch[i] == '.') cnt = 0 ; 18 else if(ch[i] == '@') 19 { 20 int j = ++ i ; 21 while(i < len && ((ch[i] >= 'a' && ch[i] <= 'z') || (ch[i] >= '0' && ch[i] <= '9'))) 22 ++ i ; 23 if(i != j && ch[i] == '.') 24 { 25 j = ++ i ; 26 a = 0 ; 27 while(i < len && (ch[i] >= 'a' && ch[i] <= 'z')) 28 { 29 i++ ; 30 a++ ; 31 } 32 ans += a*cnt ; 33 } 34 i = j-1 ; 35 cnt = 0 ; 36 } 37 } 38 printf("%I64d\n",ans) ; 39 return 0 ; 40 }