7.20 Codeforces Beta Round #8
A
原因:RE,fantasy 的字符串的长度可能大于原字符串。
B
题意:上下左右走,可能要避让障碍,问是否存在一个地图使得给定的路径为当前最短路径。
题型:构造,模拟
原因:map不熟,要判两个地方,一是不重复抵达,二是当前点除去前导点旁边的点不能事先经过。
解法:按照上面说的模拟一下就可以,这种方法相对来说效率高,但是代码写得多。可以直接遍历:一个点跟其后面步长大于1的点的距离不能小于1。
- #include <iostream>
- #include <string.h>
- #include <algorithm>
- #include <stdio.h>
- #include <string>
- #include <map>
- #include <vector>
- #include <cmath>
- #include <set>
- #define ll long long
- #define PI 3.1415926535
- #define AC ios::sync_with_stdio(0)
- using namespace std;
- const int inf=1e5+;
- #define u dit[1];
- bool cmp(const string& a,const string& b)
- {
- return a.length()<b.length();
- }
- struct pt{
- int x;
- int y;
- bool operator<(const pt&a)const{ //key为结构体时时要重载<
- if(x<a.x)
- return true;
- else if(x==a.x)
- return y<a.y;
- return false;
- }
- };
- map<pt,int>mp;
- //int dit[4][2]={-1,0,0,1,1,0,0,-1};
- string s;
- int main()
- {
- ios::sync_with_stdio();
- cin>>s;
- pt st;
- st.x=;
- st.y=;
- mp.insert(make_pair(st,)); //忘记了 wa了
- for(int i=;i<s.length();i++)
- {
- if(s[i]=='U')
- {
- st.x--;
- pt a={st.x-,st.y},b={st.x,st.y+},c={st.x,st.y-};
- if(mp.count(a)||mp.count(b)||mp.count(c))
- {
- cout<<"BUG"<<endl;
- return ;
- }
- }
- if(s[i]=='D')
- {
- st.x++;
- pt a={st.x+,st.y},b={st.x,st.y+},c={st.x,st.y-};
- if(mp.count(a)||mp.count(b)||mp.count(c))
- {
- cout<<"BUG"<<endl;
- return ;
- }
- }
- if(s[i]=='R')
- {
- st.y++;
- pt a={st.x+,st.y},b={st.x-,st.y},c={st.x,st.y+};
- if(mp.count(a)||mp.count(b)||mp.count(c))
- {
- cout<<"BUG"<<endl;
- return ;
- }
- }
- if(s[i]=='L')
- {
- st.y--;
- pt a={st.x+,st.y},b={st.x-,st.y},c={st.x,st.y-};
- if(mp.count(a)||mp.count(b)||mp.count(c))
- {
- cout<<"BUG"<<endl;
- return ;
- }
- }
- if(mp.count(st))
- {
- cout<<"BUG"<<endl;
- return ;
- }
- mp.insert(make_pair(st,)); //要用make_pair因为不会调用构造函数
- }
- cout<<"OK"<<endl;
- }
- /*下面是楼教主当年的代码*/
- #include <vector>
- #include <list>
- #include <map>
- #include <set>
- #include <deque>
- #include <queue>
- #include <stack>
- #include <bitset>
- #include <algorithm>
- #include <functional>
- #include <numeric>
- #include <utility>
- #include <sstream>
- #include <iostream>
- #include <iomanip>
- #include <cstdio>
- #include <cmath>
- #include <cstdlib>
- #include <cctype>
- #include <string>
- #include <cstring>
- #include <cstdio>
- #include <cmath>
- #include <cstdlib>
- #include <ctime>
- using namespace std;
- //BEGINTEMPLATE_BY_ACRUSH_TOPCODER
- #define SIZE(X) ((int)(X.size()))//NOTES:SIZE(
- #define LENGTH(X) ((int)(X.length()))//NOTES:LENGTH(
- #define MP(X,Y) make_pair(X,Y)//NOTES:MP(
- typedef long long int64;//NOTES:int64
- typedef unsigned long long uint64;//NOTES:uint64
- #define two(X) (1<<(X))//NOTES:two(
- #define twoL(X) (((int64)(1))<<(X))//NOTES:twoL(
- #define contain(S,X) (((S)&two(X))!=0)//NOTES:contain(
- #define containL(S,X) (((S)&twoL(X))!=0)//NOTES:containL(
- const double pi=acos(-1.0);//NOTES:pi
- const double eps=1e-;//NOTES:eps
- template<class T> inline void checkmin(T &a,T b){if(b<a) a=b;}//NOTES:checkmin(
- template<class T> inline void checkmax(T &a,T b){if(b>a) a=b;}//NOTES:checkmax(
- template<class T> inline T sqr(T x){return x*x;}//NOTES:sqr
- typedef pair<int,int> ipair;//NOTES:ipair
- template<class T> inline T lowbit(T n){return (n^(n-))&n;}//NOTES:lowbit(
- template<class T> inline int countbit(T n){return (n==)?:(+countbit(n&(n-)));}//NOTES:countbit(
- //Numberic Functions
- template<class T> inline T gcd(T a,T b)//NOTES:gcd(
- {if(a<)return gcd(-a,b);if(b<)return gcd(a,-b);return (b==)?a:gcd(b,a%b);}
- template<class T> inline T lcm(T a,T b)//NOTES:lcm(
- {if(a<)return lcm(-a,b);if(b<)return lcm(a,-b);return a*(b/gcd(a,b));}
- template<class T> inline T euclide(T a,T b,T &x,T &y)//NOTES:euclide(
- {if(a<){T d=euclide(-a,b,x,y);x=-x;return d;}
- if(b<){T d=euclide(a,-b,x,y);y=-y;return d;}
- if(b==){x=;y=;return a;}else{T d=euclide(b,a%b,x,y);T t=x;x=y;y=t-(a/b)*y;return d;}}
- template<class T> inline vector<pair<T,int> > factorize(T n)//NOTES:factorize(
- {vector<pair<T,int> > R;for (T i=;n>;){if (n%i==){int C=;for (;n%i==;C++,n/=i);R.push_back(make_pair(i,C));}
- i++;if (i>n/i) i=n;}if (n>) R.push_back(make_pair(n,));return R;}
- template<class T> inline bool isPrimeNumber(T n)//NOTES:isPrimeNumber(
- {if(n<=)return false;for (T i=;i*i<=n;i++) if (n%i==) return false;return true;}
- template<class T> inline T eularFunction(T n)//NOTES:eularFunction(
- {vector<pair<T,int> > R=factorize(n);T r=n;for (int i=;i<R.size();i++)r=r/R[i].first*(R[i].first-);return r;}
- //Matrix Operations
- const int MaxMatrixSize=;//NOTES:MaxMatrixSize
- template<class T> inline void showMatrix(int n,T A[MaxMatrixSize][MaxMatrixSize])//NOTES:showMatrix(
- {for (int i=;i<n;i++){for (int j=;j<n;j++)cout<<A[i][j];cout<<endl;}}
- template<class T> inline T checkMod(T n,T m) {return (n%m+m)%m;}//NOTES:checkMod(
- template<class T> inline void identityMatrix(int n,T A[MaxMatrixSize][MaxMatrixSize])//NOTES:identityMatrix(
- {for (int i=;i<n;i++) for (int j=;j<n;j++) A[i][j]=(i==j)?:;}
- template<class T> inline void addMatrix(int n,T C[MaxMatrixSize][MaxMatrixSize],T A[MaxMatrixSize][MaxMatrixSize],T B[MaxMatrixSize][MaxMatrixSize])//NOTES:addMatrix(
- {for (int i=;i<n;i++) for (int j=;j<n;j++) C[i][j]=A[i][j]+B[i][j];}
- template<class T> inline void subMatrix(int n,T C[MaxMatrixSize][MaxMatrixSize],T A[MaxMatrixSize][MaxMatrixSize],T B[MaxMatrixSize][MaxMatrixSize])//NOTES:subMatrix(
- {for (int i=;i<n;i++) for (int j=;j<n;j++) C[i][j]=A[i][j]-B[i][j];}
- template<class T> inline void mulMatrix(int n,T C[MaxMatrixSize][MaxMatrixSize],T _A[MaxMatrixSize][MaxMatrixSize],T _B[MaxMatrixSize][MaxMatrixSize])//NOTES:mulMatrix(
- { T A[MaxMatrixSize][MaxMatrixSize],B[MaxMatrixSize][MaxMatrixSize];
- for (int i=;i<n;i++) for (int j=;j<n;j++) A[i][j]=_A[i][j],B[i][j]=_B[i][j],C[i][j]=;
- for (int i=;i<n;i++) for (int j=;j<n;j++) for (int k=;k<n;k++) C[i][j]+=A[i][k]*B[k][j];}
- template<class T> inline void addModMatrix(int n,T m,T C[MaxMatrixSize][MaxMatrixSize],T A[MaxMatrixSize][MaxMatrixSize],T B[MaxMatrixSize][MaxMatrixSize])//NOTES:addModMatrix(
- {for (int i=;i<n;i++) for (int j=;j<n;j++) C[i][j]=checkMod(A[i][j]+B[i][j],m);}
- template<class T> inline void subModMatrix(int n,T m,T C[MaxMatrixSize][MaxMatrixSize],T A[MaxMatrixSize][MaxMatrixSize],T B[MaxMatrixSize][MaxMatrixSize])//NOTES:subModMatrix(
- {for (int i=;i<n;i++) for (int j=;j<n;j++) C[i][j]=checkMod(A[i][j]-B[i][j],m);}
- template<class T> inline T multiplyMod(T a,T b,T m) {return (T)((((int64)(a)*(int64)(b)%(int64)(m))+(int64)(m))%(int64)(m));}//NOTES:multiplyMod(
- template<class T> inline void mulModMatrix(int n,T m,T C[MaxMatrixSize][MaxMatrixSize],T _A[MaxMatrixSize][MaxMatrixSize],T _B[MaxMatrixSize][MaxMatrixSize])//NOTES:mulModMatrix(
- { T A[MaxMatrixSize][MaxMatrixSize],B[MaxMatrixSize][MaxMatrixSize];
- for (int i=;i<n;i++) for (int j=;j<n;j++) A[i][j]=_A[i][j],B[i][j]=_B[i][j],C[i][j]=;
- for (int i=;i<n;i++) for (int j=;j<n;j++) for (int k=;k<n;k++) C[i][j]=(C[i][j]+multiplyMod(A[i][k],B[k][j],m))%m;}
- template<class T> inline T powerMod(T p,int e,T m)//NOTES:powerMod(
- {if(e==)return %m;else if(e%==){T t=powerMod(p,e/,m);return multiplyMod(t,t,m);}else return multiplyMod(powerMod(p,e-,m),p,m);}
- //Point&Line
- double dist(double x1,double y1,double x2,double y2){return sqrt(sqr(x1-x2)+sqr(y1-y2));}//NOTES:dist(
- double distR(double x1,double y1,double x2,double y2){return sqr(x1-x2)+sqr(y1-y2);}//NOTES:distR(
- template<class T> T cross(T x0,T y0,T x1,T y1,T x2,T y2){return (x1-x0)*(y2-y0)-(x2-x0)*(y1-y0);}//NOTES:cross(
- int crossOper(double x0,double y0,double x1,double y1,double x2,double y2)//NOTES:crossOper(
- {double t=(x1-x0)*(y2-y0)-(x2-x0)*(y1-y0);if (fabs(t)<=eps) return ;return (t<)?-:;}
- bool isIntersect(double x1,double y1,double x2,double y2,double x3,double y3,double x4,double y4)//NOTES:isIntersect(
- {return crossOper(x1,y1,x2,y2,x3,y3)*crossOper(x1,y1,x2,y2,x4,y4)< && crossOper(x3,y3,x4,y4,x1,y1)*crossOper(x3,y3,x4,y4,x2,y2)<;}
- bool isMiddle(double s,double m,double t){return fabs(s-m)<=eps || fabs(t-m)<=eps || (s<m)!=(t<m);}//NOTES:isMiddle(
- //Translator
- bool isUpperCase(char c){return c>='A' && c<='Z';}//NOTES:isUpperCase(
- bool isLowerCase(char c){return c>='a' && c<='z';}//NOTES:isLowerCase(
- bool isLetter(char c){return c>='A' && c<='Z' || c>='a' && c<='z';}//NOTES:isLetter(
- bool isDigit(char c){return c>='' && c<='';}//NOTES:isDigit(
- char toLowerCase(char c){return (isUpperCase(c))?(c+):c;}//NOTES:toLowerCase(
- char toUpperCase(char c){return (isLowerCase(c))?(c-):c;}//NOTES:toUpperCase(
- template<class T> string toString(T n){ostringstream ost;ost<<n;ost.flush();return ost.str();}//NOTES:toString(
- int toInt(string s){int r=;istringstream sin(s);sin>>r;return r;}//NOTES:toInt(
- int64 toInt64(string s){int64 r=;istringstream sin(s);sin>>r;return r;}//NOTES:toInt64(
- double toDouble(string s){double r=;istringstream sin(s);sin>>r;return r;}//NOTES:toDouble(
- template<class T> void stoa(string s,int &n,T A[]){n=;istringstream sin(s);for(T v;sin>>v;A[n++]=v);}//NOTES:stoa(
- template<class T> void atos(int n,T A[],string &s){ostringstream sout;for(int i=;i<n;i++){if(i>)sout<<' ';sout<<A[i];}s=sout.str();}//NOTES:atos(
- template<class T> void atov(int n,T A[],vector<T> &vi){vi.clear();for (int i=;i<n;i++) vi.push_back(A[i]);}//NOTES:atov(
- template<class T> void vtoa(vector<T> vi,int &n,T A[]){n=vi.size();for (int i=;i<n;i++)A[i]=vi[i];}//NOTES:vtoa(
- template<class T> void stov(string s,vector<T> &vi){vi.clear();istringstream sin(s);for(T v;sin>>v;vi.push_bakc(v));}//NOTES:stov(
- template<class T> void vtos(vector<T> vi,string &s){ostringstream sout;for (int i=;i<vi.size();i++){if(i>)sout<<' ';sout<<vi[i];}s=sout.str();}//NOTES:vtos(
- //Fraction
- template<class T> struct Fraction{T a,b;Fraction(T a=,T b=);string toString();};//NOTES:Fraction
- template<class T> Fraction<T>::Fraction(T a,T b){T d=gcd(a,b);a/=d;b/=d;if (b<) a=-a,b=-b;this->a=a;this->b=b;}
- template<class T> string Fraction<T>::toString(){ostringstream sout;sout<<a<<"/"<<b;return sout.str();}
- template<class T> Fraction<T> operator+(Fraction<T> p,Fraction<T> q){return Fraction<T>(p.a*q.b+q.a*p.b,p.b*q.b);}
- template<class T> Fraction<T> operator-(Fraction<T> p,Fraction<T> q){return Fraction<T>(p.a*q.b-q.a*p.b,p.b*q.b);}
- template<class T> Fraction<T> operator*(Fraction<T> p,Fraction<T> q){return Fraction<T>(p.a*q.a,p.b*q.b);}
- template<class T> Fraction<T> operator/(Fraction<T> p,Fraction<T> q){return Fraction<T>(p.a*q.b,p.b*q.a);}
- //ENDTEMPLATE_BY_ACRUSH_TOPCODER
- int main()
- {
- #ifdef _MSC_VER
- freopen("input.txt","r",stdin);
- #endif
- int x[],y[];
- x[]=y[]=;
- int n=;
- char s[];
- scanf("%s",s);
- for (int i=;s[i];i++)
- {
- x[n]=x[n-];
- y[n]=y[n-];
- if (s[i]=='L') x[n]--;
- if (s[i]=='R') x[n]++;
- if (s[i]=='U') y[n]--;
- if (s[i]=='D') y[n]++;
- n++;
- }
- bool isGood=true;
- for (int i=;i<n;i++)
- for (int j=i+;j<n;j++)
- if (abs(x[i]-x[j])+abs(y[i]-y[j])<=)
- isGood=false;
- if (isGood)
- printf("OK\n");
- else
- printf("BUG\n");
- return ;
- }
7.20 Codeforces Beta Round #8的更多相关文章
- Codeforces Beta Round #80 (Div. 2 Only)【ABCD】
Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...
- Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】
Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...
- Codeforces Beta Round #13 C. Sequence (DP)
题目大意 给一个数列,长度不超过 5000,每次可以将其中的一个数加 1 或者减 1,问,最少需要多少次操作,才能使得这个数列单调不降 数列中每个数为 -109-109 中的一个数 做法分析 先这样考 ...
- Codeforces Beta Round #62 题解【ABCD】
Codeforces Beta Round #62 A Irrational problem 题意 f(x) = x mod p1 mod p2 mod p3 mod p4 问你[a,b]中有多少个数 ...
- Codeforces Beta Round #79 (Div. 2 Only)
Codeforces Beta Round #79 (Div. 2 Only) http://codeforces.com/contest/102 A #include<bits/stdc++. ...
- Codeforces Beta Round #77 (Div. 2 Only)
Codeforces Beta Round #77 (Div. 2 Only) http://codeforces.com/contest/96 A #include<bits/stdc++.h ...
- Codeforces Beta Round #76 (Div. 2 Only)
Codeforces Beta Round #76 (Div. 2 Only) http://codeforces.com/contest/94 A #include<bits/stdc++.h ...
- Codeforces Beta Round #75 (Div. 2 Only)
Codeforces Beta Round #75 (Div. 2 Only) http://codeforces.com/contest/92 A #include<iostream> ...
- Codeforces Beta Round #74 (Div. 2 Only)
Codeforces Beta Round #74 (Div. 2 Only) http://codeforces.com/contest/90 A #include<iostream> ...
随机推荐
- 遍历二叉树 traversing binary tree 线索二叉树 threaded binary tree 线索链表 线索化
遍历二叉树 traversing binary tree 线索二叉树 threaded binary tree 线索链表 线索化 1. 二叉树3个基本单元组成:根节点.左子树.右子树 以L.D.R ...
- shell脚本if语句的多种条件参数
if语句有多种写法 [root@shell-yankerp sh]# [ -f file ] && echo "yes" || echo "no" ...
- 第二单元电梯调度作业 By Wazaki
figure:first-child { margin-top: -20px; } #write ol, #write ul { position: relative; } img { max-wid ...
- Mac下StarUML的安装以及破解
1.下载地址:http://staruml.io/ 2. 打开 /Applications/StarUML.app/Contents/www/license/node/LicenseManagerDo ...
- pc端 页面 显示在手机 一行控制适配问题
<meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">
- jps命令详解
JPS 名称: jps - Java Virtual Machine Process Status Tool 命令用法: jps [options] [hostid] options:命令选项,用来对 ...
- allegro17.2 gerber 步骤
1.Manufacture -> NC -> Drill Customization... 先点击 Auto generate symbols,出来对话框后点击 YES .然后在Symbo ...
- pdf下载速度
- java mysql连接时出现的问题
当出现Caused by: java.sql.SQLException: Unknown system variable ‘tx_isolation’ 一般是mysql-connector-java的 ...
- 《linux就该这么学》第十六节课:第16,17章,Squid服务和iscsi网络存储
第十六章 squid总结: 正向代理:yum 安装后清空防火墙即可正常使用,客户端设置浏览器 透明正向代理:vim /etc/squid/squid.conf 59行:http_port 312 ...