zoukankan      html  css  js  c++  java
  • 11661


      Burger Time? 

    Everybody knows that along the more important highways there are countless fast food restaurants. One can find easily hamburgers, hot dogs, pizzas, sandwiches ... food everywhere.

    Many times the problem isn't to find a restaurant but a drugstore. After a big lunch with fast food it's normal that we need a drugstore because our stomach begins to feel pain.

    Given the locations of the restaurants and drugstores on a highway, you want to determine the minimum distance between a restaurant and a drugstore.

     

    Input 

    The first line of each test case gives an integer L ( $ leq$ L $ leq$ 2000000) indicating the length of the highway.

    The second line of each test case contains a string S of length L, showing the positions of the restaurants and drugstores along the highway in the following manner:

     

    • The character ``R'' represents a place with a restaurant.
    • The character ``D'' represents a place with a drugstore.
    • The character ``Z'' represents a place with a restaurant and a drugstore.
    • The character ``.'' represents an empty place.

    You can suppose that every test case has at least one restaurant and at least one drugstore.

    The end of the input is indicated when L = 0.

     

    Output 

    For each case in the input, print one line with the minimum distance between a restaurant and a drugstore.

     

    Sample Input 

     

    2
    RD
    5
    ..Z..
    10
    .R......D.
    10
    .R..Z...D.
    10
    ...D..R...
    25
    ..D...R.RR...DD...D.R...R
    0
    

     

    Sample Output 

     

    1
    0
    7
    0
    3
    2
    

     

    #include<cstdio>
    #include<algorithm>
    using namespace std;
    char a[2000005];
    int main()
    {
    	int n,i,j;
    	while(scanf("%d",&n)&&n)
    	{
    		int mind=2000005,j=0;
    		scanf("%s",a);
    		for(i=0;i<n;i++)
    		{
    			if(a[i]=='Z') mind=0;
    			if(a[i]!='.')
    			{
    				if(a[j]!='.'&&a[i]!=a[j])
    					mind=min(mind,i-j);
    				j=i;
    			}
    		}
    		printf("%d
    ",mind);
    	}
    	return 0;
    }
  • 相关阅读:
    ps图像渐变
    QPaintDevice: Cannot destroy paint device that is being painted
    QWidget::paintEngine: Should no longer be called
    权谋 — 朱元璋
    TL(简单)
    Access“输入的表达式中含有一个无效日期值”
    Qt label加边框
    Guardian of Decency(二分图)
    匈牙利算法的小总结
    Simple Molecules(简单)
  • 原文地址:https://www.cnblogs.com/james1207/p/3301796.html
Copyright © 2011-2022 走看看