2020寒假【gmoj2221】【rooster公鸡打鸣】【模拟】

题目描述

鸡国中有两只最喜欢打鸣的公鸡 G1 和 G2,它们每一次打鸣都有一个声音的响度值。一天清晨,G1 开始先开始打鸣,响度值为 x,G2 听到 G1 的打鸣后也开始打鸣,响度值为 y。G1 和 G2 很想把它们打鸣声音的响度值调成一样。所以它们进行了 k 次协商,每一次协商后就各自增加或减少一定的响度值再打鸣一次(打鸣的响度值不能小于 0)。G1 和 G2 生性迟钝,它们不知道其实经过 s(s≤k)次协商后,打鸣声音的响度值已经相同了。请编程帮 G1 和 G2 计算一下它们打鸣声音的响度值相同时最少经过了几次协商(即最小的 s)?
注意:如果 x 一开始就等于 y,则不需要协商。

输入

输入共 k+1 行。
第 1 行三个整数 x,y 和 k,分别表示 G1、G2 第一次打鸣时声音的响度值,共进行了 k次协商并调整打鸣声音的响度值。
接下来 k 行,每行包含 4 个整数 ai,xi,bi,yi,表示第 i 次协商 G1 增加(ai等于 1)或减少(ai等于-1)的响度值为 xi,G2 增加(bi等于 1)或减少(bi等于-1)的响度值 yi。

输出

输出 1 行一个整数,表示至少经过多少次协商后 G1 和 G2 的打鸣响度值已经相同。如果经过 k 次协商后仍然无法相同,则输出“-1”(不包含双引号)。

样例输入

Input1:

2 3 3
1 1 -1 0
-1 1 1 1
1 1 -1 1

Input2:

2 3 4
1 2 -1 2
-1 1 1 1
-1 4 1 1
1 4 1 1

Input3:

2 3 1
1 2 -1 2

样例输出
Output1:
1

Output2:
4

Output3:
-1

数据范围限制

在这里插入图片描述

提示

Sample1:
在样例 1 中,G1 和 G2 第 1 次打鸣的响度值分别为 2 和 3,不相同。第 1 次协商 G1 增加 1,G2 减少 0,响度值分别为 3 和 3,所以经过 1 次协商后它们两个打鸣的响度值已经相同。经过 3 次协商时,它们的声音也能调成一样,但至少需要 1 次协商就可以了。

Sample2:
在样例 2 中,G1 和 G2 第 1 次打鸣的响度值分别为 2 和 3,不相同。第 1 次协商后打鸣的响度值分别为 4 和 1,第 2 次协商后打鸣的响度值分别为 3 和 2,第 3 次协商后打鸣的响度值分别为 0(不能小于 0)和 3,第 4 次协商后打鸣的响度值分别为 4 和 4, 所以经过 4 次协商后它们两个打鸣的响度值相同。

Sample3:
在样例 3 中,G1 和 G2 第 1 次打鸣的响度值分别为 2 和 3,不相同。第 1 次协商 G1 增加 2,G2 减少 2,响度值分别为 4 和 1,所以经过 1 次协商后它们两个打鸣的响度值仍然无法相同,则输出“-1”。

分析

其实就是每次输入模拟当前响度的变化。。。
每次判断相等就退出。
注意特判相等的情况

上代码

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int g1,g2,k,ans,ff;
int main()
{
    freopen("rooster.in","r",stdin);
	freopen("rooster.out","w",stdout);
	cin>>g1>>g2>>k;
	if(g1==g2)
	{
		cout<<0;
		return 0;
	}
	for(int i=1;i<=k;i++)
	{
		ans++;
		int a,x,b,y;
		cin>>a>>x>>b>>y;
		if(a==1) g1+=x;
		else g1=max(0,g1-x);
		if(b==1) g2+=y;
		else g2=max(0,g2-y);
		if(g1==g2)
		{
			ff=1;
			break;
		}
	}
	if(ff==1) cout<<ans;
	else cout<<-1;
	fclose(stdin);
	fclose(stdout); 
    return 0;
}

发布了110 篇原创文章 · 获赞 100 · 访问量 8011

猜你喜欢

转载自blog.csdn.net/dglyr/article/details/105150456
今日推荐