写在前面:这道题是在NOIP2018考完后很久写的,是关于《龙虎斗》这道题目一些新的感想。
试题:龙虎斗
题目描述(大意):一条线段,共有n个点,m点左边是A的势力,右边是B的势力,你需要给任意位置加势力,在哪里加两边势力最接近。
解题思路:这道题并不是很难 (那我也只拿了80分,坑) ,主要思路就是模拟,首先读入数据,计算两边的气势分别是多少,不过计不计算天降神兵就是你的事了,这个问题不大。下面就是进行一下判断,看看两边气势是否相等,相等就不用说了,放在中间(m)上,但是如果两边气势不相等的话,就要再次进行一个判断,是放在m上好还是放在另一侧,如果左边<右边,则放在左,如果右边>左边,则放在右。
下面放上代码:
//这是考场上写的,只有八十分
//有网站作证
#include<bits/stdc++.h>
using namespace std;
long long a[100000+10]={0};
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;i++)
{
cin>