题目描述

    一条长度为n的小径上,挤满了m只蚂蚁,每只蚂蚁有一个初始前进方向(向左或是向右),蚂蚁们的前进速度相同且均为1。小径的两端,均放着上了锁的箱子,箱内盛有美味的食物,蚂蚁们争相前进离开小径。不幸的是,小径十分狭窄,当两只蚂蚁相遇时,它们不得不掉头向着相反的方向前进。当所有的蚂蚁都离开小径时,锁才能够打开,蚂蚁们才能获得美味的食物。因此,蚂蚁们十分焦虑,它们想知道,到底花费多少的时间,它们才能够吃到美味的食物。你能够帮助他们解决问题吗?

输入描述:

第一行,2个整数n,m(1≤m<n≤100000,n,m均为整数),分别代表小径的长度,蚂蚁的数量。

接下来m行,每行2个数,分别代表蚂蚁的初始方向(0代表向左,1代表向右),蚂蚁的初始坐标x满足x为整数且0<x<n,蚂蚁走到坐标0或坐标n即代表离开小径。

数据保证每个坐标上最多有1只蚂蚁。数据保证给出的蚂蚁初始坐标为从小到大。

输出描述:

一行,对结果四舍五入,输出1个整数,代表蚂蚁吃到美味的食物的时间。

示例1
输入
复制

50 10
1 6
0 15
0 19
1 20
0 22
0 25
1 36
0 39
1 40
1 42

输出
复制

44

这题很有趣,所以在写完后还是想写一片题解,防止以后忘记,这题并非模拟全部过程,那样根本不可能写出来,或者说我写不出来,两只蚂蚁碰面交换方向,因为不用去区分蚂蚁,所以可以认为所有的蚂蚁都是相同的,这样就可以看作两个蚂蚁相遇见时会互换位置,或者可以理解为穿过对方,这样就可以写出来了,只要找到一只蚂蚁理终点线最远(注意有方向),他的距离就是答案;

#include <bits/stdc++.h>
using namespace std;
long long power(int k, int a);
bool isPrime(long long n);
int main()
{
    long long a=0,b=0,d=0, i=0, T, s=0, le;
    long long a1=0, a5=0, a10=0,n,m,res=0,arr2[100000];
    char sr[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L'};
    int N,R,sym=1, arr[100000];
    float gpa, s_gpa=0;
    char c;
    string str;

    cin>>n>>m;
//     a=100000;
//     b=-100000;
    for (i=0;i<m;i++){
//         printf("%d/%d\n",a,b);
        cin>>d>>s;
        if (d==1) s = (n-s); 
        res = max(res,s);
    }

    
    cout<<res<<endl;
    
//     printf("%lld %lld %lld %lld",max-max2,max-min2,max2-min2,max2-min);
    
//         cout<<b-a<<endl;
//     printf("%.2f %d %d",double(s)/n,b,a);

//     if (sym > 0)
//         str = "Nancy";
//     else
//         str = "Johnson";
//     cout<<str<<endl;

    

    
//     cin>>T;
//     for (int i=0; i<T; i++) {
//         cin>>n;
//         if (n==1) {
//             printf("No\n");
//             continue;
//         }
//         b=0;
//         for(int j=2;j<n-1;j++){
//             if (n % j == 0) {
                
//                 b=1;
//                 break;
//             }
//         }
//         if (b==1) {
//             printf("No\n");
//         } else {
//             cout<<"Yes"<<endl;
//         }
        
        
        
        
//     }
        
//         printf("%.1f", res);
    

            
            
        
   
    // cout<<"positive:"<<endl;
    // cout<<"negative:"<<b<<endl;
}

long long power(int k, int a) {
    if (a == 0) return 1;
    long long res = 1;
    for (int i=0; i<a; i++) {
        res *= k;
    }
    return res;
}

bool isPrime(long long n) {
    for(int j=2;j<n-1;j++){
        if (n % j == 0) {
            return false;
        }
    }
    return true;
}
posted on 2022-06-14 09:26  Akarinnnn  阅读(200)  评论(0编辑  收藏  举报