京东烽火台

#include<iostream>
#include<vector>
using namespace std;

bool isok(int i, int j, vector<int>&h)
{
int ci = i+1;
while (h[ci] <= h[i] && h[ci] <= h[j]&&ci<j)
{
ci++;
}
if (ci == j)
return true;
int cj = j+1;
bool fa = true;
if (cj == h.size())
{
cj = 0;
fa = false;
}
while (h[cj] <= h[i] && h[cj] <= h[j]&&((!fa&&cj<i)||fa))
{
cj++;
if (cj == h.size())
{
cj = 0;
fa = false;
}
}
if (cj == i)
return true;
return false;
}

int main()
{
int n;
while (cin >> n)
{
vector<int>hill(n);
for (int i = 0; i<n; i++)
{
cin >> hill[i];
}
int cnt = n;
vector<vector<int>> p(n, vector<int>(n, 0));
for (int i = 0; i<n; i++)
{
for (int j = i; j<n; j++)
{
if (p[i][j] == 0)
{
p[i][j] = 1;
p[j][i] = 1;
}
else if (p[i][j] == 1)
continue;
if (i == j||abs(i-j)==1||(i==0&&j==n-1))
continue;
if (isok(i, j, hill))
{
cout << i << j << endl;
cnt++;
}
}
}
cout << cnt << endl;
}
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 11:35
程序员小白条:话太多,没实力和学历,差不多回答回答就行了,身份地位不一样
点赞 评论 收藏
分享
06-17 21:57
门头沟学院 Java
白友:噗嗤,我发现有些人事就爱发这些,明明已读不回就行了,就是要恶心人
点赞 评论 收藏
分享
06-26 17:24
已编辑
宁波大学 golang
迷失西雅图:别给,纯kpi,别问我为什么知道
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务