链接:codeforces.com/contest/8

A

原因:RE,fantasy 的字符串的长度可能大于原字符串。

B

题意:上下左右走,可能要避让障碍,问是否存在一个地图使得给定的路径为当前最短路径。

题型:构造,模拟

原因:map不熟,要判两个地方,一是不重复抵达,二是当前点除去前导点旁边的点不能事先经过。

解法:按照上面说的模拟一下就可以,这种方法相对来说效率高,但是代码写得多。可以直接遍历:一个点跟其后面步长大于1的点的距离不能小于1。

PS:make_pair的使用方法

map中key值为结构体的用法

  1. #include <iostream>
  2. #include <string.h>
  3. #include <algorithm>
  4. #include <stdio.h>
  5. #include <string>
  6. #include <map>
  7. #include <vector>
  8. #include <cmath>
  9. #include <set>
  10. #define ll long long
  11. #define PI 3.1415926535
  12. #define AC ios::sync_with_stdio(0)
  13. using namespace std;
  14. const int inf=1e5+;
  15. #define u dit[1];
  16.  
  17. bool cmp(const string& a,const string& b)
  18. {
  19. return a.length()<b.length();
  20. }
  21. struct pt{
  22. int x;
  23. int y;
  24. bool operator<(const pt&a)const{ //key为结构体时时要重载<
  25. if(x<a.x)
  26. return true;
  27. else if(x==a.x)
  28. return y<a.y;
  29. return false;
  30. }
  31. };
  32. map<pt,int>mp;
  33. //int dit[4][2]={-1,0,0,1,1,0,0,-1};
  34. string s;
  35. int main()
  36. {
  37. ios::sync_with_stdio();
  38. cin>>s;
  39. pt st;
  40. st.x=;
  41. st.y=;
  42. mp.insert(make_pair(st,)); //忘记了 wa了
  43. for(int i=;i<s.length();i++)
  44. {
  45. if(s[i]=='U')
  46. {
  47. st.x--;
  48. pt a={st.x-,st.y},b={st.x,st.y+},c={st.x,st.y-};
  49. if(mp.count(a)||mp.count(b)||mp.count(c))
  50. {
  51. cout<<"BUG"<<endl;
  52. return ;
  53. }
  54. }
  55. if(s[i]=='D')
  56. {
  57. st.x++;
  58. pt a={st.x+,st.y},b={st.x,st.y+},c={st.x,st.y-};
  59. if(mp.count(a)||mp.count(b)||mp.count(c))
  60. {
  61. cout<<"BUG"<<endl;
  62. return ;
  63. }
  64. }
  65. if(s[i]=='R')
  66. {
  67. st.y++;
  68. pt a={st.x+,st.y},b={st.x-,st.y},c={st.x,st.y+};
  69. if(mp.count(a)||mp.count(b)||mp.count(c))
  70. {
  71. cout<<"BUG"<<endl;
  72. return ;
  73. }
  74. }
  75. if(s[i]=='L')
  76. {
  77. st.y--;
  78. pt a={st.x+,st.y},b={st.x-,st.y},c={st.x,st.y-};
  79. if(mp.count(a)||mp.count(b)||mp.count(c))
  80. {
  81. cout<<"BUG"<<endl;
  82. return ;
  83. }
  84. }
  85. if(mp.count(st))
  86. {
  87. cout<<"BUG"<<endl;
  88. return ;
  89. }
  90. mp.insert(make_pair(st,)); //要用make_pair因为不会调用构造函数
  91. }
  92. cout<<"OK"<<endl;
  93.  
  94. }
  1. /*下面是楼教主当年的代码*/
  2. #include <vector>
  3. #include <list>
  4. #include <map>
  5. #include <set>
  6. #include <deque>
  7. #include <queue>
  8. #include <stack>
  9. #include <bitset>
  10. #include <algorithm>
  11. #include <functional>
  12. #include <numeric>
  13. #include <utility>
  14. #include <sstream>
  15. #include <iostream>
  16. #include <iomanip>
  17. #include <cstdio>
  18. #include <cmath>
  19. #include <cstdlib>
  20. #include <cctype>
  21. #include <string>
  22. #include <cstring>
  23. #include <cstdio>
  24. #include <cmath>
  25. #include <cstdlib>
  26. #include <ctime>
  27.  
  28. using namespace std;
  29.  
  30. //BEGINTEMPLATE_BY_ACRUSH_TOPCODER
  31. #define SIZE(X) ((int)(X.size()))//NOTES:SIZE(
  32. #define LENGTH(X) ((int)(X.length()))//NOTES:LENGTH(
  33. #define MP(X,Y) make_pair(X,Y)//NOTES:MP(
  34. typedef long long int64;//NOTES:int64
  35. typedef unsigned long long uint64;//NOTES:uint64
  36. #define two(X) (1<<(X))//NOTES:two(
  37. #define twoL(X) (((int64)(1))<<(X))//NOTES:twoL(
  38. #define contain(S,X) (((S)&two(X))!=0)//NOTES:contain(
  39. #define containL(S,X) (((S)&twoL(X))!=0)//NOTES:containL(
  40. const double pi=acos(-1.0);//NOTES:pi
  41. const double eps=1e-;//NOTES:eps
  42. template<class T> inline void checkmin(T &a,T b){if(b<a) a=b;}//NOTES:checkmin(
  43. template<class T> inline void checkmax(T &a,T b){if(b>a) a=b;}//NOTES:checkmax(
  44. template<class T> inline T sqr(T x){return x*x;}//NOTES:sqr
  45. typedef pair<int,int> ipair;//NOTES:ipair
  46. template<class T> inline T lowbit(T n){return (n^(n-))&n;}//NOTES:lowbit(
  47. template<class T> inline int countbit(T n){return (n==)?:(+countbit(n&(n-)));}//NOTES:countbit(
  48. //Numberic Functions
  49. template<class T> inline T gcd(T a,T b)//NOTES:gcd(
  50. {if(a<)return gcd(-a,b);if(b<)return gcd(a,-b);return (b==)?a:gcd(b,a%b);}
  51. template<class T> inline T lcm(T a,T b)//NOTES:lcm(
  52. {if(a<)return lcm(-a,b);if(b<)return lcm(a,-b);return a*(b/gcd(a,b));}
  53. template<class T> inline T euclide(T a,T b,T &x,T &y)//NOTES:euclide(
  54. {if(a<){T d=euclide(-a,b,x,y);x=-x;return d;}
  55. if(b<){T d=euclide(a,-b,x,y);y=-y;return d;}
  56. 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;}}
  57. template<class T> inline vector<pair<T,int> > factorize(T n)//NOTES:factorize(
  58. {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));}
  59. i++;if (i>n/i) i=n;}if (n>) R.push_back(make_pair(n,));return R;}
  60. template<class T> inline bool isPrimeNumber(T n)//NOTES:isPrimeNumber(
  61. {if(n<=)return false;for (T i=;i*i<=n;i++) if (n%i==) return false;return true;}
  62. template<class T> inline T eularFunction(T n)//NOTES:eularFunction(
  63. {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;}
  64. //Matrix Operations
  65. const int MaxMatrixSize=;//NOTES:MaxMatrixSize
  66. template<class T> inline void showMatrix(int n,T A[MaxMatrixSize][MaxMatrixSize])//NOTES:showMatrix(
  67. {for (int i=;i<n;i++){for (int j=;j<n;j++)cout<<A[i][j];cout<<endl;}}
  68. template<class T> inline T checkMod(T n,T m) {return (n%m+m)%m;}//NOTES:checkMod(
  69. template<class T> inline void identityMatrix(int n,T A[MaxMatrixSize][MaxMatrixSize])//NOTES:identityMatrix(
  70. {for (int i=;i<n;i++) for (int j=;j<n;j++) A[i][j]=(i==j)?:;}
  71. template<class T> inline void addMatrix(int n,T C[MaxMatrixSize][MaxMatrixSize],T A[MaxMatrixSize][MaxMatrixSize],T B[MaxMatrixSize][MaxMatrixSize])//NOTES:addMatrix(
  72. {for (int i=;i<n;i++) for (int j=;j<n;j++) C[i][j]=A[i][j]+B[i][j];}
  73. template<class T> inline void subMatrix(int n,T C[MaxMatrixSize][MaxMatrixSize],T A[MaxMatrixSize][MaxMatrixSize],T B[MaxMatrixSize][MaxMatrixSize])//NOTES:subMatrix(
  74. {for (int i=;i<n;i++) for (int j=;j<n;j++) C[i][j]=A[i][j]-B[i][j];}
  75. template<class T> inline void mulMatrix(int n,T C[MaxMatrixSize][MaxMatrixSize],T _A[MaxMatrixSize][MaxMatrixSize],T _B[MaxMatrixSize][MaxMatrixSize])//NOTES:mulMatrix(
  76. { T A[MaxMatrixSize][MaxMatrixSize],B[MaxMatrixSize][MaxMatrixSize];
  77. 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]=;
  78. 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];}
  79. template<class T> inline void addModMatrix(int n,T m,T C[MaxMatrixSize][MaxMatrixSize],T A[MaxMatrixSize][MaxMatrixSize],T B[MaxMatrixSize][MaxMatrixSize])//NOTES:addModMatrix(
  80. {for (int i=;i<n;i++) for (int j=;j<n;j++) C[i][j]=checkMod(A[i][j]+B[i][j],m);}
  81. template<class T> inline void subModMatrix(int n,T m,T C[MaxMatrixSize][MaxMatrixSize],T A[MaxMatrixSize][MaxMatrixSize],T B[MaxMatrixSize][MaxMatrixSize])//NOTES:subModMatrix(
  82. {for (int i=;i<n;i++) for (int j=;j<n;j++) C[i][j]=checkMod(A[i][j]-B[i][j],m);}
  83. 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(
  84. template<class T> inline void mulModMatrix(int n,T m,T C[MaxMatrixSize][MaxMatrixSize],T _A[MaxMatrixSize][MaxMatrixSize],T _B[MaxMatrixSize][MaxMatrixSize])//NOTES:mulModMatrix(
  85. { T A[MaxMatrixSize][MaxMatrixSize],B[MaxMatrixSize][MaxMatrixSize];
  86. 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]=;
  87. 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;}
  88. template<class T> inline T powerMod(T p,int e,T m)//NOTES:powerMod(
  89. {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);}
  90. //Point&Line
  91. double dist(double x1,double y1,double x2,double y2){return sqrt(sqr(x1-x2)+sqr(y1-y2));}//NOTES:dist(
  92. double distR(double x1,double y1,double x2,double y2){return sqr(x1-x2)+sqr(y1-y2);}//NOTES:distR(
  93. 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(
  94. int crossOper(double x0,double y0,double x1,double y1,double x2,double y2)//NOTES:crossOper(
  95. {double t=(x1-x0)*(y2-y0)-(x2-x0)*(y1-y0);if (fabs(t)<=eps) return ;return (t<)?-:;}
  96. bool isIntersect(double x1,double y1,double x2,double y2,double x3,double y3,double x4,double y4)//NOTES:isIntersect(
  97. {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)<;}
  98. bool isMiddle(double s,double m,double t){return fabs(s-m)<=eps || fabs(t-m)<=eps || (s<m)!=(t<m);}//NOTES:isMiddle(
  99. //Translator
  100. bool isUpperCase(char c){return c>='A' && c<='Z';}//NOTES:isUpperCase(
  101. bool isLowerCase(char c){return c>='a' && c<='z';}//NOTES:isLowerCase(
  102. bool isLetter(char c){return c>='A' && c<='Z' || c>='a' && c<='z';}//NOTES:isLetter(
  103. bool isDigit(char c){return c>='' && c<='';}//NOTES:isDigit(
  104. char toLowerCase(char c){return (isUpperCase(c))?(c+):c;}//NOTES:toLowerCase(
  105. char toUpperCase(char c){return (isLowerCase(c))?(c-):c;}//NOTES:toUpperCase(
  106. template<class T> string toString(T n){ostringstream ost;ost<<n;ost.flush();return ost.str();}//NOTES:toString(
  107. int toInt(string s){int r=;istringstream sin(s);sin>>r;return r;}//NOTES:toInt(
  108. int64 toInt64(string s){int64 r=;istringstream sin(s);sin>>r;return r;}//NOTES:toInt64(
  109. double toDouble(string s){double r=;istringstream sin(s);sin>>r;return r;}//NOTES:toDouble(
  110. 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(
  111. 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(
  112. 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(
  113. 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(
  114. 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(
  115. 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(
  116. //Fraction
  117. template<class T> struct Fraction{T a,b;Fraction(T a=,T b=);string toString();};//NOTES:Fraction
  118. 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;}
  119. template<class T> string Fraction<T>::toString(){ostringstream sout;sout<<a<<"/"<<b;return sout.str();}
  120. 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);}
  121. 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);}
  122. template<class T> Fraction<T> operator*(Fraction<T> p,Fraction<T> q){return Fraction<T>(p.a*q.a,p.b*q.b);}
  123. template<class T> Fraction<T> operator/(Fraction<T> p,Fraction<T> q){return Fraction<T>(p.a*q.b,p.b*q.a);}
  124. //ENDTEMPLATE_BY_ACRUSH_TOPCODER
  125.  
  126. int main()
  127. {
  128. #ifdef _MSC_VER
  129. freopen("input.txt","r",stdin);
  130. #endif
  131. int x[],y[];
  132. x[]=y[]=;
  133. int n=;
  134. char s[];
  135. scanf("%s",s);
  136. for (int i=;s[i];i++)
  137. {
  138. x[n]=x[n-];
  139. y[n]=y[n-];
  140. if (s[i]=='L') x[n]--;
  141. if (s[i]=='R') x[n]++;
  142. if (s[i]=='U') y[n]--;
  143. if (s[i]=='D') y[n]++;
  144. n++;
  145. }
  146. bool isGood=true;
  147. for (int i=;i<n;i++)
  148. for (int j=i+;j<n;j++)
  149. if (abs(x[i]-x[j])+abs(y[i]-y[j])<=)
  150. isGood=false;
  151. if (isGood)
  152. printf("OK\n");
  153. else
  154. printf("BUG\n");
  155. return ;
  156. }

7.20 Codeforces Beta Round #8的更多相关文章

  1. Codeforces Beta Round #80 (Div. 2 Only)【ABCD】

    Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...

  2. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

  3. Codeforces Beta Round #13 C. Sequence (DP)

    题目大意 给一个数列,长度不超过 5000,每次可以将其中的一个数加 1 或者减 1,问,最少需要多少次操作,才能使得这个数列单调不降 数列中每个数为 -109-109 中的一个数 做法分析 先这样考 ...

  4. 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]中有多少个数 ...

  5. Codeforces Beta Round #79 (Div. 2 Only)

    Codeforces Beta Round #79 (Div. 2 Only) http://codeforces.com/contest/102 A #include<bits/stdc++. ...

  6. Codeforces Beta Round #77 (Div. 2 Only)

    Codeforces Beta Round #77 (Div. 2 Only) http://codeforces.com/contest/96 A #include<bits/stdc++.h ...

  7. Codeforces Beta Round #76 (Div. 2 Only)

    Codeforces Beta Round #76 (Div. 2 Only) http://codeforces.com/contest/94 A #include<bits/stdc++.h ...

  8. Codeforces Beta Round #75 (Div. 2 Only)

    Codeforces Beta Round #75 (Div. 2 Only) http://codeforces.com/contest/92 A #include<iostream> ...

  9. Codeforces Beta Round #74 (Div. 2 Only)

    Codeforces Beta Round #74 (Div. 2 Only) http://codeforces.com/contest/90 A #include<iostream> ...

随机推荐

  1. 遍历二叉树 traversing binary tree 线索二叉树 threaded binary tree 线索链表 线索化

    遍历二叉树   traversing binary tree 线索二叉树 threaded binary tree 线索链表 线索化 1. 二叉树3个基本单元组成:根节点.左子树.右子树 以L.D.R ...

  2. shell脚本if语句的多种条件参数

    if语句有多种写法 [root@shell-yankerp sh]# [ -f file ] && echo "yes" || echo "no" ...

  3. 第二单元电梯调度作业 By Wazaki

    figure:first-child { margin-top: -20px; } #write ol, #write ul { position: relative; } img { max-wid ...

  4. Mac下StarUML的安装以及破解

    1.下载地址:http://staruml.io/ 2. 打开 /Applications/StarUML.app/Contents/www/license/node/LicenseManagerDo ...

  5. pc端 页面 显示在手机 一行控制适配问题

    <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">

  6. jps命令详解

    JPS 名称: jps - Java Virtual Machine Process Status Tool 命令用法: jps [options] [hostid] options:命令选项,用来对 ...

  7. allegro17.2 gerber 步骤

    1.Manufacture -> NC -> Drill Customization... 先点击 Auto generate symbols,出来对话框后点击 YES .然后在Symbo ...

  8. pdf下载速度

  9. java mysql连接时出现的问题

    当出现Caused by: java.sql.SQLException: Unknown system variable ‘tx_isolation’ 一般是mysql-connector-java的 ...

  10. 《linux就该这么学》第十六节课:第16,17章,Squid服务和iscsi网络存储

    第十六章 squid总结: 正向代理:yum  安装后清空防火墙即可正常使用,客户端设置浏览器 透明正向代理:vim  /etc/squid/squid.conf 59行:http_port  312 ...