$Codeforces\; Round\; 504\; (Div.2)$
宾馆的\(\rm{wifi}\)也太不好了,蹭的\(ZZC\)的热点才打的比赛(感谢\(ZZC\))
日常掉rating…… 我现在是个\(\color{green}{pupil}\)……
因为我菜,所以还是只写了前三道题
题解
\(\mathcal{A.Single\; Wildcard\; Pattern\; Matching}\)
题目大意:有点长,不想翻译了qwq
我能说第一题是前三道题中最难的么……各种特判,各种被卡,最后交了4遍也没做出来(我太蒟了 QAQ)
反复修改后的冗杂的AC代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int main(){
int n,m; cin>>n>>m; n-=1,m-=1;
if(n>m+1){
cout<<"NO"; return 0;
}
char s1[200010],s2[200010]; cin>>s1>>s2;
int pos=0;
for(int i=0;i<=n+1;i++){
pos=i;
if(s1[i]=='*') break;
}
//cout<<pos;
for(int i=0;i<pos;i++){
if(s1[i]!=s2[i]){
cout<<"NO"; return 0;
}
}
if(pos==n+1){
if(n!=m){
cout<<"NO"; return 0;
}
goto hhh;
}
int j;
for(j=0;;j++){
if(n-j==pos) break;
if(s1[n-j]!=s2[m-j]){
cout<<"NO"; return 0;
}
}
for(int i=pos;i<m-j;i++){
if(s2[i]<'a'||s2[i]>'z'){
cout<<"NO"; return 0;
}
}
hhh:
cout<<"YES";
return 0;
}
\(\mathfrak{B.Pair\; of\; Toys}\)
题目大意:输入两个数\(n,k\),问从\(1\text{~}n\)中取出\(2\)个数使得它们的和为\(k\)的方案数(\((a,b)\)和\((b,a)\)算同一种方案)
这题算是数论吧……挺简单的
如果\(a+b==k\),那么\((a+1)+(b-1),(a+2)+(b+2)\)……也等于\(k\)。所以我们可以找到最接近的两个数\(k/2,k/2+1\),然后\(1\text{~}k/2\)和\((k/2+1)\text{~}(k{-}1)\)就是所有的方案。接下来我们只需要找出合法的方案数就可以了
首先我们可以确定如果\(k/2{>=}n\),肯定无解,当\(k/2{<}n\)的时候,因为\(n\)可能小于\(k\),所以合法的方案数应为\(\min(k/2,(k-1)-k/2,n-k/2)\)
P.S. 不要忘了开\(long\; long\)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int main(){
long long n,k; cin>>n>>k;
long long mid=k/2,ans;
if(mid<n) ans=min(mid,min(k-1-mid,n-mid));
else{
cout<<0; return 0;
}
cout<<ans;
return 0;
}
\(\sf{C.Bracket\; Subsequence}\)
题目大意:给你一个长度为\(n\)括号序列\(a\),找出一段长度为\(m\)合法的括号序列\(b\),使得\(b\)是\(a\)的子串
\(b\)为答案,我们枚举\(a\)的每一个括号,每扫到一个括号,就把它加入\(b\)里,如果为左括号,\(cnt{+}{=}1\),如果\(cnt==m/2\)就跳出循环,然后从后面补右括号就行了
没初始化\(ans\)数组,FST了…… QAQ
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int main(){
int n,m; cin>>n>>m; m/=2;
char a[200010],b[200010]; cin>>a;
memset(b,0,sizeof(b));
int len=strlen(a)-1,tot=0,cnt=0;
for(int i=0;i<=len;i++){
if(a[i]=='('){
b[tot++]='(';
cnt++;
}
if(cnt==m) break;
if(a[i]==')'){
b[tot++]=')';
}
}
for(int i=tot;i<m*2;i++) b[i]=')';
cout<<b;
return 0;
}
总结
这次比赛暴露了我以下几个问题:
- 不够认真、仔细,对特殊情况考虑不全
- 代码中总存在一些小问题
- 太浮躁,认为第一遍测试过了就万事大吉了,没有检查代码的隐藏\(bug\)
- 太过依赖于样例和测试数据
随机推荐
- Codeforces 358D【DP】
思路: dp[i][0] 代表取的时候左边没有 dp[i][1] 代表取的时候右边没有 dp[i][2] 代表取的时候左右都没有 dp[i][3] 代表取的时候左右都有 然后自己转移吧= =. 注意 ...
- Android 跨应用调用Activity
http://blog.csdn.net/ouyangliping/article/details/7972141 如何调用另外一个app应用的activity或者service,本文提供一个验证可行 ...
- MySql 5.6 遇到的一些问题
1. 卸载5.5之后,使用 mysql installer 时,没法设定 data directory . 最后再次删除mysql installer之后,使系统干净后才能重新安装, 然后界面出现了 ...
- IT兄弟连 JavaWeb教程 JSP内置对象经典面试题
1.请说明cookie.request.session.application的作用域和声明周期? 并说明它们适用与什么场景? request的生命周期是一次请求.可以用于JSP表单提交数据. ses ...
- python+unittest 搭建简易的接口测试框架
主要介绍如何使用python+unittest快速搭建一个接口测试的框架 1.安装python unittest 2.新建一个python项目ApiTest 在setUp和setDown里设置一些需 ...
- math(2018.10.27)
20%的数据直接暴搜就行,接下来我们考虑哪些数不能够出现在同一个集合中,就连一 条边,我们会发现前
- css实现发光的input输入框
效果图截图: 案例代码示下: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...
- JS面向对象方法(二) 面向对象方法实现橱窗式图面预览以及放大功能
效果图: HTML结构如下: <div id="preview"> <div id="mediumDiv"> <img id=& ...
- shell 中的if语句
if [ t != "." -a t != ".." ] 之前一直不知道 -a 是什么意思,后来才知道 -a = and ; -o = or
- C#的特性学习
转自:https://www.cnblogs.com/rohelm/archive/2012/04/19/2456088.html 特性提供功能强大的方法,用以将元数据或声明信息与代码(程序集.类 ...