51NOD-1390 游戏得分

news/2025/2/9 9:44:24/

题目链接:
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1390

A与B两人玩一个游戏,这个游戏有若干个回合(可能0回合)。游戏的回合依次标号为1,2,3,4…。你不需要关心游戏的内容,现在只要知道第i回合胜者会获得2*i-1分,每回合游戏不存在平局。现在已知A和B在游戏结束时各获得了x分与y分的总分。问A在这个游戏中至少获胜了几盘?如果给出的x与y一定不会出现那么输出-1.
Input
多组测试数据,第一行一个整数T,表示测试数据数量,1<=T<=5
每组测试数据有相同的结构构成:
每组数据一行包含两个整数x,y,表示A与B最后的总得分,其中0<=x,y<=1,000,000,000,000。
Output
每组数据一行输出,即A最少获胜了几盘,非法的x与y对输出-1。


思路:
1、sum=a+b;由题意我们可以知道sum=(2*1+2*2+…+2*n)-n;
由等差数列公式可得sum=n^2,故可知当sqrt(sum)不为整数时则非法,再一个就是a,b均不能为2。
2、由 (1) 可知所求的 n 为总回合数,于是我们只需遍历A在 1~n 个回合中有解即可(有解就可以停止遍历,只要求最小回合数)
3、核心(遍历过程):每回合增加2*i-1,我们可以把减少的 1 补上,假设 a 补上减少的 1 后的数为 t,若有解,则 t 必定要为偶数,并且 t 不超过 ( (n-k+1) +…+ (n-1) + n ) * 2。( k 即A赢的回合数)
4、注意下精度,整数直接全开long long 好了,被这个坑了一晚上……T_T,第一次刷51的4级题,满满的压力!!!!


AC代码:

#include <iostream>
#include <cmath>
using namespace std;#define LL long longint main()
{LL a,b,sum;LL T;cin>>T;while(T--){cin>>a>>b;sum=a+b;double tmp=sqrt(sum*1.0);LL count;if(tmp!=floor(tmp)||a==2||b==2){cout<<-1<<endl;continue;}elsecount=tmp;//回合总数if(!b)//当b为0时可以直接输出回合总数{cout<<count<<endl;continue;}LL t = 0;bool flag = false;LL num=0;for(LL i=1;i<=count;++i)//{if(i>a)break;t=a+i;num=(2*count-i+1)*i/2;if(t%2==0&&((LL)(t/2.0+0.5)<=num)){cout<<i<<endl;flag = true;break;}}if(!flag)cout<<0<<endl;}return 0;
}

http://www.ppmy.cn/news/576651.html

相关文章

1390: 时间间隔(多实例测试)

1390: 时间间隔&#xff08;多实例测试&#xff09; 1.描述 从键盘输入两个时间点(24小时制&#xff09;&#xff0c;输出两个时间点之间的时间间隔&#xff0c;时间间隔用“小时:分钟:秒”表示。 输入 输入数据有多组。每组输入包括两行。第一行为时间点1&#xff0c;第二行…

poj 1390

题意&#xff1a;一个方块消除的游戏&#xff0c;每次可以消除颜色相同的方块&#xff0c;每次得分是你消除的格子的数量的平方。 黑书上的一题。 参照《算法艺术》上的算法 题目的方块可以表示称color[i],len[i],1<i<l 这里l表示有多少"段"不同的颜色方块 co…

1390 Prepared statement contains too many placeholders

以前的一个项目&#xff0c;在进行mysql执行预插入语句的时候&#xff0c;如果预插入的数据条数过多&#xff0c;则会报错。 具体报错为&#xff1a; 1390 Prepared statement contains too many placeholders 字面意思大概是预执行语句包含了太多的占位符。 查询了相关的资料…

c++作业3-F(1390)

Problem F: 时间类的常量 Time Limit: 4 Sec Memory Limit: 128 MB Submit: 5927 Solved: 4758 [Submit][Status] Description 封装一个时间类Time&#xff0c;用于时间处理的相关功能&#xff0c;支持以下操作&#xff1a; 1. Time::Time()无参构造方法。 2. Time::Tim…

1397

Goldbachs Conjecture Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 4667 Accepted Submission(s): 1754 题目链接&#xff1a; http://acm.hdu.edu.cn/showproblem.php?pid1397 Problem Description Gold…

hdu 1390 Binary Numbers

题目地址&#xff1a; http://acm.hdu.edu.cn/showproblem.php?pid1390 题目描述&#xff1a; Binary Numbers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 2834 Accepted Submission(s): 1758 Probl…

【路径规划】基于matlab Hybrid A_Star算法机器人路径规划【含Matlab源码 1390期】

⛄一、A_star算法简介 1 A Star算法及其应用现状 进行搜索任务时提取的有助于简化搜索过程的信息被称为启发信息.启发信息经过文字提炼和公式化后转变为启发函数.启发函数可以表示自起始顶点至目标顶点间的估算距离, 也可以表示自起始顶点至目标顶点间的估算时间等.描述不同的…

BZOJ 1390 [CEOI2008] Fence 题解

纪念一下&#xff0c;调了整整两周。 本题题意非常清晰&#xff0c;故不提供题意简述。 Solution 注意到 20 4 < 111 20\times 4<111 204<111&#xff0c;所以即使花 4 4 4 个点包住一棵树也是值的。所以我们考虑包住最多的树&#xff0c;这样一定是最优的。 所…