Topcoder SRM652div2
开始接触Topcode..div2..
250题目:
Problem Statement
You are given a String s consisting of lower case letters. We assign the letters 'a' to 'z' values of to , respectively. We will denote the value assigned to the letter X by val[X]. For example, val['a'] = and val['e'] = .
We define the value of the string s as follows. For each letter s[i], let k[i] be the number of letters in s that are less than or equal to s[i], including s[i] itself. Then, the value of s is defined to be the sum of k[i] * val[s[i]] for all valid i.
Given the string, compute and return the value of the string.
Definition
Class:
ValueOfString
Method:
findValue
Parameters:
String
Returns:
int
Method signature:
int findValue(String s)
(be sure your method is public)
Limits
Time limit (s):
2.000
Memory limit (MB): Stack limit (MB): Constraints
-
s will contain between and characters, inclusive.
-
s will consist of lowercase letters ('a'-'z').
Examples
)
"babca"
Returns:
The value of this string is * + * + * + * + * = .
We can get the value as follows. The first character is a 'b' which has value , and has characters that are less than or equal to it in the string (i.e. the first, second, third and fifth character of the string). Thus, this first character contributes * to the sum. We can derive a similar expression for each of the other characters.
)
"zz"
Returns: )
"y"
Returns: )
"aaabbc"
Returns: )
"topcoder"
Returns: )
"thequickbrownfoxjumpsoverthelazydog"
Returns: )
"zyxwvutsrqponmlkjihgfedcba"
Returns: This problem statement is the exclusive and proprietary property of TopCoder, Inc. Any unauthorized use or reproduction of this information without the prior written consent of TopCoder, Inc. is strictly prohibited. (c), TopCoder, Inc. All rights reserved.
根据题意直接搞~
代码:
#include <string>
#include <vector>
#include <algorithm>
#include <cstring>
using namespace std; class ValueOfString
{
public:
int findValue( string s )
{
int res = ;
int cnt[] , val[] ;
for( int i = ; i < ; ++i ) {
cnt[i] = ; val[i] = i + ;
}
for( int i = ; i < s.length() ; ++i ) {
cnt[ s[i]-'a' ]++;
}
for( int i = ; i < ; ++i ) cnt[i] += cnt[i-] ;
for( int i = ; i < s.length() ; ++i ) {
res += cnt[ s[i] - 'a' ] * val[ s[i]-'a' ] ;
}
return res ;
}
};
500题目:
Problem Statement
Alice and Bob are playing a game called "The Permutation Game". The game is parameterized with the int N. At the start of the game, Alice chooses a positive integer x, and Bob chooses a permutation of the first N positive integers. Let p be Bob's permutation. Alice will start at 1, and apply the permutation to this value x times. More formally, let f(1) = p[1], and f(m) = p[f(m-1)] for all m >= 2. Alice's final value will be f(x). Alice wants to choose the smallest x such that f(x) = for any permutation Bob can provide. Compute and return the value of such x.
Definition
Class:
ThePermutationGameDiv2
Method:
findMin
Parameters:
int
Returns:
long long
Method signature:
long long findMin(int N)
(be sure your method is public)
Limits
Time limit (s):
2.000
Memory limit (MB): Stack limit (MB): Notes
-
The return value will fit into a signed -bit integer.
-
A permutation of the first N positive integers is a sequence of length N that contains each of the integers through N exactly once. The i-th (-indexed) element of a permutation p is denoted by p[i].
Constraints
-
N will be between and inclusive.
Examples
) Returns:
Bob can choose the permutations {,} or {,}. If Alice chooses , then, Bob can choose the permutation {,}, which would would make f() = . However, if Alice chooses , no matter which permutation Bob chooses, Alice will get f() = . Thus the answer in this case is .
) Returns: ) Returns: ) Returns: ) Returns: This problem statement is the exclusive and proprietary property of TopCoder, Inc. Any unauthorized use or reproduction of this information without the prior written consent of TopCoder, Inc. is strictly prohibited. (c), TopCoder, Inc. All rights reserved.
模拟完yy一下应该是 1 ~ n 的 LCM , 结果对了。。
代码:
#include <string>
#include <vector>
#include <algorithm>
#include <cstring>
using namespace std; class ThePermutationGameDiv2
{
public:
long long gcd( long long a , long long b ) { return b == ? a : gcd( b , a % b ) ; }
long long LCM( long long a , long long b ) { return a/gcd(a,b)*b; }
long long findMin( int n )
{
long long res = ;
for( int i = ; i <= n ; ++i ) {
res = LCM( res , i ) ;
}
return res ;
}
};
1000题目:
Problem Statement
Roger the Robot has been sent to explore a planet. The surface of the planet can be thought of as a two-dimensional plane. You are given two int[]s x and y. The planet has N interesting points described by these int[]s. The i-th interesting point has coordinates (x[i], y[i]). No three interesting points will be collinear.
Roger will choose a permutation of {,,...,N-}, and will visit the points in that order. Roger will travel in a straight line in between points. There are two conditions he must follow:
He must never cross his own path (that is, if we look at the line segments formed by the path, no two segments strictly intersect).
Due to rather unfortunate oversight, Roger is incapable of making any right turns. This means that for any three consecutive points that he visits, these three points constitute a counter-clockwise orientation.
Your job is to find a path that Roger can take. If there is no valid path, return an empty int[]. Otherwise, return an int[] containing a permutation of ,...,N-, representing a valid path that Roger can take.
Definition
Class:
NoRightTurnDiv2
Method:
findPath
Parameters:
int[], int[]
Returns:
int[]
Method signature:
int[] findPath(int[] x, int[] y)
(be sure your method is public)
Limits
Time limit (s):
2.000
Memory limit (MB): Stack limit (MB): Constraints
-
x will contain between and elements, inclusive.
-
y will contain exactly the same number of elements as x.
-
Each element of x,y will be between -, and ,, inclusive.
-
All pairs (x[i], y[i]) will be distinct.
-
No three points will be collinear.
Examples
)
{-, , }
{, -, }
Returns: {, , }
The points form a triangle. Any of the following return values will be accepted: {,,},{,,},{,,}
)
{,,-,-,,}
{-,,-,,-,}
Returns: {, , , , , }
Here is a picture of the points: Here is an example of a different valid solution. This would correspond to a return value of {,,,,,} )
{,,,,,,,,,}
{,,,,,,,,,}
Returns: {, , , , , , , , , } )
{, ,-, ,-, ,-, }
{, , , , , , , }
Returns: {, , , , , , , } )
{-,,,,-,,,,,,-,-,-,,-,-,-,-,,,,,
,-,,,,,,-,,-,-,,-,-,,-,,,,-,-,,
,,,,-,}
{-,,,-,-,,,,,-,-,-,,-,,-,,-,-,-,,-,
,-,-,,,-,,,,-,-,-,-,-,,,,-,-,-,-,
-,,,-,-,,-}
Returns:
{, , , , , , , , , , , , , , , , , , ,
, , , , , , , , , , , , , , , , , ,
, , , , , , , , , , , , } This problem statement is the exclusive and proprietary property of TopCoder, Inc. Any unauthorized use or reproduction of this information without the prior written consent of TopCoder, Inc. is strictly prohibited. (c), TopCoder, Inc. All rights reserved.
给出n个点求出一条路径,这路径必须满足只能向左拐,能够走过n个点,路径没有交叉的方案。
先找出边角点作为起点,然后贪心,枚举点,找左拐角度最微的点作为下一个点
代码:
#include <string>
#include <cstdio>
#include <iostream>
#include <vector>
#include <algorithm>
#include <cstring>
#include <map>
using namespace std;
typedef pair<int,int> pii;
const int N = ;
struct Point {
int x , y , idx ;
Point(){};
Point( int x , int y ):x(x),y(y){}
bool operator < ( const Point a )const {
if( x != a.x ) return x < a.x;
else return y < a.y ;
}
}p[N]; Point operator - ( const Point a , const Point b ){
return Point( a.x - b.x , a.y - b.y );
} int Cross( Point A , Point B ) { return A.x*B.y-A.y*B.x; } bool vis[N]; class NoRightTurnDiv2
{
public:
vector<int> findPath( vector<int> x, vector<int> y )
{
vector<int>res ;
int n = x.size();
for( int i = ; i < n ; ++i ) {
p[i].x = x[i] , p[i].y = y[i];
p[i].idx = i ;
if( p[i].y < p[].y || p[i].y == p[].y && p[i].x > p[].x ) swap( p[] , p[i] );
}
memset( vis , false , sizeof vis );
vis[] = true ; res.push_back( p[].idx );
int pre = ;
for( int i = ; i < n ; ++i ) {
int now = - ;
for( int j = ; j < n ; ++j ) if( !vis[j] ) {
if( now == - ) now = j ;
else {
if( Cross( p[pre] - p[now] , p[pre] - p[j] ) <= ) {
now = j ;
}
}
}
vis[now] = true ;
res.push_back( p[now].idx ) ;
pre = now ;
}
return res ;
}
};
Topcoder SRM652div2的更多相关文章
- TopCoder kawigiEdit插件配置
kawigiEdit插件可以提高 TopCoder编译,提交效率,可以管理保存每次SRM的代码. kawigiEdit下载地址:http://code.google.com/p/kawigiedit/ ...
- 记第一次TopCoder, 练习SRM 583 div2 250
今天第一次做topcoder,没有比赛,所以找的最新一期的SRM练习,做了第一道题. 题目大意是说 给一个数字字符串,任意交换两位,使数字变为最小,不能有前导0. 看到题目以后,先想到的找规律,发现要 ...
- TopCoder比赛总结表
TopCoder 250 500 ...
- Topcoder几例C++字符串应用
本文写于9月初,是利用Topcoder准备应聘时的机试环节临时补习的C++的一部分内容.签约之后,没有再进行练习,此文暂告一段落. 换句话说,就是本文太监了,一直做草稿看着别扭,删掉又觉得可惜,索性发 ...
- TopCoder
在TopCoder下载好luncher,网址:https://www.topcoder.com/community/competitive%20programming/ 选择launch web ar ...
- TopCoder SRM 596 DIV 1 250
body { font-family: Monospaced; font-size: 12pt } pre { font-family: Monospaced; font-size: 12pt } P ...
- 求拓扑排序的数量,例题 topcoder srm 654 div2 500
周赛时遇到的一道比较有意思的题目: Problem Statement There are N rooms in Maki's new house. The rooms are number ...
- TopCoder SRM 590
第一次做TC,不太习惯,各种调试,只做了一题...... Problem Statement Fox Ciel is going to play Gomoku with her friend ...
- Topcoder Arena插件配置和训练指南
一. Arena插件配置 1. 下载Arena 指针:http://community.topcoder.com/tc?module=MyHome 左边Competitions->Algorit ...
随机推荐
- Postman初探
缘起 今天要测试一个新接口,返回值应该是现有6个接口返回值中data.CountNum之和.麻烦处有: 1.用户角色不同,接口返回值也有不同.因此要用到的接口很多. 2.要对所有接口的返回值求和,再与 ...
- tomcat的跳转与日志
1.跳转的关键性配置; 2. 日志的配置 1.跳转的关键性配置 当用户访问http://www.a.com/test时,会跳转打开/var/www/html目录下的页面 关键性配置如下: [root@ ...
- windows重装系统之前与之后进行的操作
1.原系统的备份 避免重装遇到故障无法恢复,给自己留一条后路. 重装系统之前首先进行一次系统备份,我使用的备份软件是dism++,这个软件还可以完成其他的诸如空间回收.系统优化等操作: 软件地址:ht ...
- Linux 实操(root密码重置 无法上网 安装xrdp)
一个是显示器显示不咋地,一个是想远程连接Linux,这样就可以放到下面机房去了.所以想安装一个远程桌面链接.从网上搜了搜,好多.安装的时候需要root权限,但是密码忘了.好吧,开始捣鼓root密码 按 ...
- cp 复制文件或目录
1. 命令功能 cp --copy files and directories.复制文件或目录. 2. 语法格式 cp [option] source des cp [option] sour ...
- 洛谷P3158 [CQOI2011]放棋子 组合数学+DP
题意:在一个m行n列的棋盘里放一些彩色的棋子,使得每个格子最多放一个棋子,且不同颜色的棋子不能在同一行或者同一列.有多少祌方法? 解法:这道题不会做,太菜了qwq.题解是看洛谷大佬的. 设C是组合数, ...
- 如何查看Codeforces的GYM中比赛的数据
前置条件:黄名(rating >= 2100) 或者 紫名(rating >= 1900)并且打过30场计分的比赛. 开启:首先打开GYM的界面,如果符合要求会在右边展示出一个Coach ...
- spring requestbody json
1 @requestbody string param 前台将jsonobject序列化成字符串 后台解析成JsonObject 2 @requestbody map<string,objec ...
- 基于 Ansible 的 ELK 部署说明
ELK-Ansible使用手册 ELK-Ansible 是基于 Ansible 的 Playbooks 研发的 ELK集群部署工具.本文将介绍如何使用 ELK-Ansible 快速部署 ELK 集群. ...
- $LCT$维护子树信息学习笔记
\(LCT\)维护子树信息学习笔记 昨天\(FDF\)好题分享投了 \([ZJOI2018]\)历史 这题. 然后我顺势学学这个姿势. 结果调了一年...于是写个笔记记录一下. 基本原理 比较显然地, ...