UVa11093 Just Finish it up (贪心+思路)
2017-06-30 11:12
344 查看
题目链接:https://vjudge.net/problem/UVA-11093
题目大意:是否有足够的油让你走完全程
题目思路:枚举n个加油站的作为起点然后模拟整个过程,但是不能一个一个的枚举,当某个起点走到p位置时无法到达p+1点时,直接从p+1位置作为起点开始模拟即可,因为之前的再枚举也没有用了,当走到p点照样没油,所以2,3,4,5到p为起点枚举都是无解的,所以直接跳过就好,所以复杂度是O(n),所有遍历一遍即可,当最后一个点也被走过后还不能走完一圈就是无解。
代码:
#include <iostream>
#include <cstdio>
using namespace std;
const int maxn = 100000 + 5;
int p[maxn],q[maxn];
inline int solve(int n){
int start = 0;
while(start < n){//起始点扫一遍
int cnt = 0,oil = 0,i=start,flag = 0;
while(cnt < n){//进行模拟
oil += p[i];//加油
if(oil >= q[i]){//可以到达下一站
oil -= q[i++];//消耗
if(i == n){i %= n;flag = 1;}//当到达末尾时,进行取膜回到0位置,且标记已经走过所有的点了(不代表一趟都走完),如果没能全部就说明无法走完,标记
cnt++;//累计站点数
}
else {start = i+1;break;}//更新从i+1点开始再进行模拟
}
if(cnt == n) return start+1;//所有站点都走过,返回开始位置
if(flag) return -1;//无法走完
}
return -1;
}
int main()
{
int t,n;
scanf("%d",&t);
for(int kcase=1;kcase<=t;kcase++){
scanf("%d",&n);
for(int i=0;i<n;i++) scanf("%d",&p[i]);
for(int i=0;i<n;i++) scanf("%d",&q[i]);
int ans = solve(n);
printf("Case %d: ",kcase);
if(ans == -1) printf("Not possible\n");
else printf("Possible from station %d\n",ans);
}
return 0;
}
题目大意:是否有足够的油让你走完全程
题目思路:枚举n个加油站的作为起点然后模拟整个过程,但是不能一个一个的枚举,当某个起点走到p位置时无法到达p+1点时,直接从p+1位置作为起点开始模拟即可,因为之前的再枚举也没有用了,当走到p点照样没油,所以2,3,4,5到p为起点枚举都是无解的,所以直接跳过就好,所以复杂度是O(n),所有遍历一遍即可,当最后一个点也被走过后还不能走完一圈就是无解。
代码:
#include <iostream>
#include <cstdio>
using namespace std;
const int maxn = 100000 + 5;
int p[maxn],q[maxn];
inline int solve(int n){
int start = 0;
while(start < n){//起始点扫一遍
int cnt = 0,oil = 0,i=start,flag = 0;
while(cnt < n){//进行模拟
oil += p[i];//加油
if(oil >= q[i]){//可以到达下一站
oil -= q[i++];//消耗
if(i == n){i %= n;flag = 1;}//当到达末尾时,进行取膜回到0位置,且标记已经走过所有的点了(不代表一趟都走完),如果没能全部就说明无法走完,标记
cnt++;//累计站点数
}
else {start = i+1;break;}//更新从i+1点开始再进行模拟
}
if(cnt == n) return start+1;//所有站点都走过,返回开始位置
if(flag) return -1;//无法走完
}
return -1;
}
int main()
{
int t,n;
scanf("%d",&t);
for(int kcase=1;kcase<=t;kcase++){
scanf("%d",&n);
for(int i=0;i<n;i++) scanf("%d",&p[i]);
for(int i=0;i<n;i++) scanf("%d",&q[i]);
int ans = solve(n);
printf("Case %d: ",kcase);
if(ans == -1) printf("Not possible\n");
else printf("Possible from station %d\n",ans);
}
return 0;
}
相关文章推荐
- [贪心]UVa11093 - Just Finish it up
- uva11093 Just Finish it up(思路)
- uva11093 just finish it up
- Uva11093 Just Finish it up【模拟】【例题8-13】
- uva 11093-Just Finish it up【贪心?链表】
- UVA 11093 Just Finish it up 环形跑道 (贪心)
- Uva 11093 Just Finish it up——思路题
- Uva - 11093 - Just Finish it up
- Uva 11093 Just Finish it up
- uva 11093——Just Finish it up
- UVa OJ 11093 - Just Finish it up
- UVa #11093 Just Finish it up (例题8-13)
- UVA - 11093 Just Finish it up 环路
- UVA 11093 Just Finish it up(模拟题)
- 【例题 8-13 UVA - 11093】Just Finish it up
- UVA-11093 Just Finish it up
- 例题8-13 环形跑道(Just Finish it up, UVa 11093)
- UVA11093:Just Finish it up(环形跑道)
- uva 11093 just finish it up
- 【高效算法设计——跳跃枚举】Uva 11093 Just Finish it up