zoukankan      html  css  js  c++  java
  • CodeForces

    Sonya decided that having her own hotel business is the best way of earning money because she can profit and rest wherever she wants.

    The country where Sonya lives is an endless line. There is a city in each integer coordinate on this line. She has nn hotels, where the ii-th hotel is located in the city with coordinate xixi. Sonya is a smart girl, so she does not open two or more hotels in the same city.

    Sonya understands that her business needs to be expanded by opening new hotels, so she decides to build one more. She wants to make the minimum distance from this hotel to all others to be equal to dd. The girl understands that there are many possible locations to construct such a hotel. Thus she wants to know the number of possible coordinates of the cities where she can build a new hotel.

    Because Sonya is lounging in a jacuzzi in one of her hotels, she is asking you to find the number of cities where she can build a new hotel so that the minimum distance from the original nn hotels to the new one is equal to dd.

    Input

    The first line contains two integers nn and dd (1≤n≤1001≤n≤100, 1≤d≤1091≤d≤109) — the number of Sonya's hotels and the needed minimum distance from a new hotel to all others.

    The second line contains nn different integers in strictly increasing order x1,x2,…,xnx1,x2,…,xn (−109≤xi≤109−109≤xi≤109) — coordinates of Sonya's hotels.

    Output

    Print the number of cities where Sonya can build a new hotel so that the minimum distance from this hotel to all others is equal to dd.

    Examples

    Input

    4 3
    -3 2 9 16
    

    Output

    6
    

    Input

    5 2
    4 8 11 18 19
    

    Output

    5
    

    Note

    In the first example, there are 66 possible cities where Sonya can build a hotel. These cities have coordinates −6−6, 55, 66, 1212, 1313, and 1919.

    In the second example, there are 55 possible cities where Sonya can build a hotel. These cities have coordinates 22, 66, 1313, 1616, and 2121.

    题解:

    判断是否有交叉,如果有就不加,没有就加差值,但是差值最大只能是2,超过2的当2算

    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    #include<iostream>
    
    using namespace std;
    
    int main()
    {
    	
    	int n,d;
    	cin>>n>>d;
    	int a[105];
    	for(int t=0;t<n;t++)
    	{
    		scanf("%d",&a[t]);
    	}
    	sort(a,a+n);
    	long long int sum=2;
    	for(int t=0;t<n-1;t++)
    	{
    	    if(a[t]+d<=a[t+1]-d)
    	    {
    	    	if((a[t+1]-a[t]-2*d+1)>2)
    	    	sum+=2;
    	    	else
    	    	sum+=a[t+1]-a[t]-2*d+1;
    		}
    	}
    	cout<<sum<<endl;
    	
    	return  0;
    }
  • 相关阅读:
    [转]Centos 查看端口占用情况和开启端口命令
    [转]简单美观的文字标签云组件
    [转]scp、sftp命令使用
    清华大学《C++语言程序设计基础》线上课程笔记03---数据的共享和保护&数组
    清华大学《C++语言程序设计基础》线上课程笔记02---类与对象
    清华大学《C++语言程序设计基础》线上课程笔记01---基础概念与一些注意事项
    新的玩具:Windows上的awesome
    环境变量ANDROID_SDK_HOME的作用
    Android Dalvik和JVM的区别
    是否使用TDD(测试驱动开发)进行UI开发
  • 原文地址:https://www.cnblogs.com/Staceyacm/p/10781911.html
Copyright © 2011-2022 走看看