Wannafly挑战赛3 record

B 遇见

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 65536K,其他语言131072K
64bit IO Format: %lld
题目描述
A和B在同一条路上,他们之间的距离为 k 米。A现在想见到B,所以A开车以 x km/h的速度朝着B的方向行驶,同时B也以 y km/h的速度朝着A的方向走去。A的车有 n 个档位,每个档位有不同的速度。现在假设A开车去见B,求他最快和最慢在几秒后能见到B。
输入描述:
一开始一行三个整数 n, m, k ,代表A的车的档位数、B行走的速度和AB之间的距离。
接下来一行 n 个整数,代表A的车的不同档位的行驶速度。
输出描述:
一行两个整数,代表A最快/最慢在几秒后能见到B(向上取整)。
示例1
输入

5 20 80
30 15 10 5 -5
输出

6 20
备注:
对于所有数据,0 <= n <= 1000,-100000 <= A车速度 <= 100000,-A最慢速度 < B行走速度 <= 100000,0 <= k <= 100000.
题目保证最大值和最小值都有解。

签到题:

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 typedef long long ll;
 4 int main() {
 5     ll n;
 6     double m,k,data,minnum=100001,maxnum=-100001;
 7     cin>>n>>m>>k;
 8     k=k*1.0/1000;
 9     for(int i=0;i<n;++i) cin>>data,minnum=min(data,minnum),maxnum=max(data,maxnum);
10     if(n==0) maxnum=minnum=0;
11     double mintime=k*1.0/(maxnum+m);
12     double maxtime=k*1.0/(minnum+m);
13     mintime=mintime*60*60;
14     maxtime=maxtime*60*60;
15     if(mintime-(int)mintime>1e-6) cout<<((int)mintime)+1<<" ";
16     else cout<<(int)mintime<<" ";
17     if(maxtime-(int)maxtime>1e-6) cout<<((int)maxtime)+1<<endl;
18     else cout<<(int)maxtime<<endl;
19     return 0;
20 }

D Butterfly2

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 65536K,其他语言131072K
64bit IO Format: %lld
题目描述
给定一个 n*m 的矩阵,矩阵元素由X和O构成,请求出其中最大的蝴蝶形状。
蝴蝶形状的定义如下:
存在一个中心点(必须为X),并且其往左上(必须为X)、左下(必须为X)、右上(必须为O)、右下(必须为O)四个方向扩展相同的长度,且左上顶点与左下顶点之间全由X填充,右上顶点与右下顶点之间全由O填充。
我们不在意在蝴蝶形状内部是X还是O。
例如:
XAAAO
XXAOO
XAXAO
XXAOO
XAAAO
是一个蝴蝶形状(其中A表示X或O)。
X
也是。

XAAO
XXOO
XXOO
XAAO
不是(不存在中心点)。

输入描述:
第一行两个整数n, m表示矩阵的大小 (1 <= n, m <= 500);
接下来 n 行,每行一个长度为 m 的字符串表示矩阵,矩阵元素保证由X和O构成。
输出描述:
一行一个整数表示最大的蝴蝶形状的对角线的长度。
示例1
输入

输出5 5
XOOOO
XXOOO
XOXOO
XXOOO
XOOOO

5

继续签到:DFS

 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 const int N=505;
 4 int res=0,n,m;
 5 char ans[N][N];
 6 void dfs(int x, int y, int ins) {
 7     int x1,x2,y1,y2;
 8     x1=x+ins*(-1);
 9     x2=x+ins;
10     y1=y+ins*(-1);
11     y2=y+ins;
12     int flag=1;
13     if(x1<0||x1>=n||y1<0||y1>=m||x2<0||x2>=n||y2<0||y2>=m) {
14         flag=0;
15     }
16     if(flag==0) return;
17     if(ans[x1][y1]!=‘X‘||ans[x2][y1]!=‘X‘||ans[x1][y2]!=‘O‘||ans[x2][y2]!=‘O‘) {
18         flag=0;
19     }
20     if(flag==0) return;
21     dfs(x,y,ins+1);
22     for(int i=x1;i<=x2;++i) {
23         if(ans[i][y1]!=‘X‘||ans[i][y2]!=‘O‘) {
24             flag=0;
25             break;
26         }
27     }
28     if(flag==0) return;
29     res=max(res,2*ins+1);
30 }
31
32 int main() {
33     ios::sync_with_stdio(false);
34     cin>>n>>m;
35     for(int i=0;i<n;++i) for(int j=0;j<m;++j) cin>>ans[i][j];
36     for(int i=0;i<n;++i)
37         if(ans[i][0]==‘X‘||ans[i][m-1]==‘X‘) {
38             res=1;break;
39         }
40     for(int i=0;i<m;++i)
41         if(ans[0][i]==‘X‘||ans[n-1][i]==‘X‘) {
42             res=1;break;
43         }
44     for(int i=1;i<=n-2;++i) {
45         for(int j=1;j<=m-2;++j) {
46             if(ans[i][j]==‘X‘)
47                 dfs(i,j,1);
48         }
49     }
50     cout<<res<<endl;
51     return 0;
52 }

时间: 2024-11-10 17:02:03

Wannafly挑战赛3 record的相关文章

Wannafly挑战赛3

Wannafly挑战赛3 A    珂朵莉 B    遇见 水题 #include<bits/stdc++.h> using namespace std; #pragma comment(linker, "/STACK:102400000,102400000") #define rep(i,a,b) for (int i=a; i<=b; ++i) #define per(i,b,a) for (int i=b; i>=a; --i) #define mes(a

【Wannafly挑战赛4】F 线路规划 倍增+Kruskal+归并

[Wannafly挑战赛4]F 线路规划 题目描述 Q国的监察院是一个神秘的组织.这个组织掌握了整个帝国的地下力量,监察着Q国的每一个人.监察院一共有N个成员,每一个成员都有且仅有1个直接上司,而他只听从其上直接司的命令.其中1号成员是监察院的院长,这个庞然大物的主人.由于时代的进步,监察院议会决定升级组织的旧式通信器,安装最新的反侦测通信器.他们拿出了M组线路方案,其中第i组线路方案可以用一个四元组(x[i].y[i].k[i].w[i])描述,表示第x[i]号成员可以安装与y[i]号成员的直

牛客网 Wannafly挑战赛8 C-小C打比赛 (状压DP)

小C现在要参加一场wannafly挑战赛,一场挑战赛一共有n道题,一共有m分钟. 对于第i道题,小C解决它需要恰好j分钟的概率是pi,j. 小C每次会选择某一道没做完的题,然后把它解决(不能中途放弃),之后再决策下一道要做的题是哪道. 求小C在最优策略下,期望能做出几道题. 输入描述: 第一行两个正整数n,m接下来一共n行,每行有m个小数,第i行的第j个小数表示p i,j (这里假设不存在0分钟A题的dalao). 输出描述: 输出一个小数,表示期望能做出几道题,保留小数点后五位. 示例1 输入

Wannafly挑战赛11 D 白兔的字符串 Hash

Wannafly挑战赛11 D   白兔的字符串 白兔有一个字符串T.白云有若干个字符串S1,S2..Sn. 白兔想知道,对于白云的每一个字符串,它有多少个子串是和T循环同构的. 提示:对于一个字符串a,每次把a的第一个字符移动到最后一个,如果操作若干次后能够得到字符串b,则a和b循环同构. 所有字符都是小写英文字母 输入描述: 第一行一个字符串T(|T|<=10^6)第二行一个正整数n (n<=1000)接下来n行为S1~Sn (|S1|+|S2|+…+|Sn|<=10^7),max(

Wannafly挑战赛18

Wannafly挑战赛18 A. 序列 先考虑暴力,相邻两个树之间乘上给定的三种数,递推出下一个位置填什么,然后再check一下,最后一位是否为1即可.这样时间显然不行,但是给我们一种思路,就是中间的转换关系,确定唯一一个序列.现在的目标是让最后一位出现1,可以如果不管1,由-2和0.5取凑出1需要两个-2和两个0.5.那所有的转换中,就只要保证有若干组(-2,-2,0.5,0.5)存在,其他地方为1即可.具体公式见代码 #include <bits/stdc++.h> #define rep

Wannafly挑战赛19

Wannafly挑战赛19 A. 队列Q 需要支持把一个元素移到队首,把一个元素移到队尾,移到队首就直接放到队首前面那个位置,原位置标为0,队尾同理. #include <bits/stdc++.h> #define rep(i,a,b) for(int i=a;i<=b;++i) typedef long long ll; const int N = 30000200; using namespace std; int n,m; int q[N],hd,x,ed,P[N]; char

Wannafly挑战赛22游记

Wannafly挑战赛22游记 幸福的人都是相似的,不幸的人各有各的不幸. --题记 A-计数器 题目大意: 有一个计数器,计数器的初始值为\(0\),每次操作你可以把计数器的值加上\(a_1,a_2,\ldots,a_n\)中的任意一个整数,操作次数不限(可以为\(0\)次),问计数器的值对\(m\)取模后有几种可能. 思路: 由裴蜀定理易得,答案即为\(\frac m{\gcd(m,a_1,a_2,\ldots,a_n)}\). 源代码: #include<cstdio> #include

Wannafly挑战赛25游记

Wannafly挑战赛25游记 A - 因子 题目大意: 令\(x=n!(n\le10^{12})\),给定一大于\(1\)的正整数\(p(p\le10000)\)求一个\(k\)使得\(p^k|x\)并且\(p^{k+1}\not|x\)的因子. 思路: 枚举\(p\)的每一个质因数\(q\),求出它在\(n!\)出现次数\(/p\)中出现次数,取\(\min\)即可.对于一个质因数\(q\),在\(n!\)中出现的次数等于\(\sum_{i=1}^{\inf}\frac n{q^i}\).

Wannafly挑战赛1,2

做了好久了,今天大佬讲题,好厉害,弱鸡只会几道水题. Treepath 给定一棵n个点的树,问其中有多少条长度为偶数的路径.路径的长度为经过的边的条数.x到y与y到x被视为同一条路径.路径的起点与终点不能相同. 奇数层到奇数层,偶数层到偶数层. Xorto 给定一个长度为n的整数数组,问有多少对互不重叠的非空区间,使得两个区间内的数的异或和为0. 异或题好厉害,问题变成四个点的异或值为0. 厉害的位置是他的遍历方式O(n*nlogn) 左区间+1个元素,将产生一些新的异或值,有区间探测.(枚举的