标签:style blog http io color os ar java for
题目来源:A Mountaineer (不知道该链接是否可以直接访问,所以将题目复制下来了)
题目如下:
Time limit : 2sec / Stack limit : 256MB / Memory limit : 256MB
Dave is a mountaineer. He is now climbing a range of mountains.
On this mountains, there are N huts located on a straight lining from east to west..
The huts are numbered sequentially from 1 to N. The west most hut is 1, the east most hut is N. The i-th hut is located at an elevation of hi meters.
Dave wants to know how many huts he can look down and see from each hut.
He can see the j-th hut from the i-th hut if all huts between the i-th hut and the j-th hut including the j-th one are located at equal or lower elevation than hi.
Note that the i-th hut itself is not included in the hut he can see from the i-th hut.
The input will be given in the following format from the Standard Input.
N h1 h2 : hN
Your answer will be checked for two levels.
On the i-th line, output the number of huts Dave can see from the i-th hut. Make sure to insert a line break at the end of the output.
3
1
2
3
0
1
2
From each hut he can see every huts on the west.
5
1
2
3
2
1
0
1
4
1
0
From the 1st and 5th hut he can‘t see any other huts.
From the 2nd hut he can only see the 1st hut.
From the 4th hut he can only see the 5th hut.
From the 3rd hut he can see every other huts.
5
3
2
1
2
3
4
2
0
2
4
Note that he can see the huts on the equal elevation.
8
4
3
2
3
4
3
2
1
7
2
0
2
7
2
1
0
由于题目比较简单,所以就不翻译了。
算法一解题思路(时间复杂度O(n^2))
假设输入序列为 a1,a2,...,ai-1,ai,ai+1,...,an,如果要求ai所能看见的huts个数,则需要依次统计ai左边和右边小于ai的个数和。
具体算法(java版,TLE)
1 import java.util.Scanner; 2 3 public class Main { 4 5 public static void main(String[] args) { 6 Scanner scanner = new Scanner(System.in); 7 int n = scanner.nextInt(); 8 int[] array = new int[n]; 9 for (int i = 0; i < n; i++) { 10 array[i] = scanner.nextInt(); 11 } 12 for (int i = 0; i < n; i++) { 13 int value = array[i]; 14 int count = 0; 15 int j = i - 1; 16 int k = i + 1; 17 while (j >= 0 && array[j] <= value) { 18 count++; 19 j--; 20 } 21 while (k < n && array[k] <= value) { 22 count++; 23 k++; 24 } 25 System.out.println(count); 26 } 27 } 28 }
算法二解题思路(时间复杂度O(n))
分析一下算法一为什么会比较慢,其主要原因是会有大量重复的计算。假设我们已经知道ai-1左边小于ai-1的huts个数m了,如果ai大于ai-1,则ai左边huts的个数一定大于等于m+1,我们不妨将下标从ai-1向左移动m位,然后再比较ai与n=ai-m-1所对应的值,如果ai对应的值大于等于n对应的值,依次计算。然后用同样的方法计算右边的值,最后将左边和右边的值相加就可以得到正确结果。
具体算法(java版,直接AC)
1 import java.util.Scanner; 2 3 public class Main { 4 5 public static void main(String[] args) { 6 Scanner scanner = new Scanner(System.in); 7 int n = scanner.nextInt(); 8 int[] array = new int[n]; 9 for (int i = 0; i < n; i++) { 10 array[i] = scanner.nextInt(); 11 } 12 int[] ansLeft = new int[n]; 13 int[] ansRight = new int[n]; 14 for (int i = 0; i < n; i++) { 15 int value = array[i]; 16 if (i > 0) { 17 int k = i - 1; 18 if (value < array[k]) { 19 ansLeft[i] = 0; 20 } else { 21 while (k >= 0 && array[k] <= value) { 22 ansLeft[i] += ansLeft[k] + 1; 23 k = k - ansLeft[k] - 1; 24 } 25 } 26 } 27 } 28 for (int i = n - 1; i >= 0; i--) { 29 int value = array[i]; 30 if (i < n - 1) { 31 int k = i + 1; 32 if (value < array[k]) { 33 ansRight[i] = 0; 34 } else { 35 while (k < n && array[k] <= value) { 36 ansRight[i] += ansRight[k] + 1; 37 k = k + ansRight[k] + 1; 38 } 39 } 40 } 41 } 42 for (int i = 0; i < n; i++) { 43 System.out.println(ansLeft[i] + ansRight[i]); 44 } 45 } 46 }
标签:style blog http io color os ar java for
原文地址:http://www.cnblogs.com/pinxiong/p/4068384.html