当前位置:   article > 正文

区间最小值(2) (线段树 更新区间)2015年 JXNU_ACS 算法组暑假第一次周赛_区间最小值小于s

区间最小值小于s

区间最小值(2)

Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 65535/32768K (Java/Other)
Total Submission(s) : 26   Accepted Submission(s) : 9
Font: Times New Roman | Verdana | Georgia
Font Size:  

Problem Description

给定一个数字序列以及一些操作,查询任意给定区间内数字的最小值。

Input

输入包含多组测试数据,最多5组。
输入包含多组测试用例,每组测试用例的开头为一个整数n(1<=n<=100000),代表数字序列的长度。
接下去一行给出n个数字,代表数字序列。数字在int范围内。
下一行为一个整数t(1<=t<=10000),代表操作的次数。
最后t行,每行给出一个操作,1 l r代表查询区间 [l,r]的最小值,0 l r c代表将区间[l r]的值全部替换为c (1<=l<=r<=n),c在整形范围内。

Output

对于每个查询,输出区间[l,r]内的最小值。

Sample Input

5
1 2 3 4 5
7
1 1 5
0 1 3 6
1 1 4
1 2 3
0 2 2 0
1 1 2
1 3 5

Sample Output

1
4
6
0
4

Author

吴迎

Statistic |  Submit |  Back

迟到了五分钟才做了。。感觉做的是对的。虽然没能提交上。

找了一天了。。TM我终于找到怎么做了。。上午的时候其实就知道怎么更新区间了,只不过一个地方写错了

导致结果不对 就放弃了。。

今天下午尝试了那么多。。o(︶︿︶)o 唉 刚刚发现上午写的是对的。

  1. <pre name="code" class="cpp">#include <stdio.h>
  2. #include <string.h>
  3. #include <algorithm>
  4. using namespace std;
  5. int num[100005];
  6. struct node
  7. {
  8. int left,right,val;
  9. }c[100005*4];
  10. void build_tree(int l,int r,int root)
  11. {
  12. c[root].left=l;
  13. c[root].right=r;
  14. if(l==r)
  15. {
  16. c[root].val=num[l];
  17. return ;
  18. }
  19. int mid=(l+r)/2;
  20. build_tree(l,mid,root*2);
  21. build_tree(mid+1,r,root*2+1);
  22. c[root].val=min(c[root*2].val,c[root*2+1].val);
  23. }
  24. void find_tree(int l,int r,int &min1,int root)
  25. {
  26. if(c[root].left==l&&c[root].right==r)
  27. {
  28. min1=c[root].val;
  29. return ;
  30. }
  31. int mid=(c[root].left+c[root].right)/2;
  32. if(mid<l)
  33. find_tree(l,r,min1,root*2+1);
  34. else if(mid>=r)
  35. find_tree(l,r,min1,root*2);
  36. else
  37. {
  38. int min2;
  39. find_tree(l,mid,min1,root*2);
  40. find_tree(mid+1,r,min2,root*2+1);
  41. min1=min(min1,min2);
  42. }
  43. }
  44. void update_tree(int l,int r,int x,int root)
  45. {
  46. if(c[root].left==c[root].right)
  47. {
  48. c[root].val=x;
  49. return ;
  50. }
  51. int mid=(c[root].left+c[root].right)/2;
  52. if(mid<l)
  53. update_tree(l,r,x,root*2+1);
  54. else if(mid>=r)
  55. update_tree(l,r,x,root*2);
  56. else
  57. {
  58. update_tree(l,mid,x,root*2);
  59. update_tree(mid+1,r,x,root*2+1);
  60. }
  61. c[root].val=min(c[root*2].val,c[root*2+1].val);
  62. }
  63. int main()
  64. {
  65. int n,k;
  66. while(scanf("%d",&n)!=EOF)
  67. {
  68. for(int i=1;i<=n;i++)
  69. scanf("%d",&num[i]);
  70. build_tree(1,n,1);
  71. scanf("%d",&k);
  72. while(k--)
  73. {
  74. int a,b,min1,flag;
  75. scanf("%d",&flag);
  76. if(flag)
  77. {
  78. scanf("%d %d",&a,&b);
  79. find_tree(a,b,min1,1);
  80. printf("%d\n",min1);
  81. }
  82. else
  83. {
  84. int x;
  85. scanf("%d %d %d",&a,&b,&x);
  86. update_tree(a,b,x,1);
  87. //for(int i=1;i<=9;i++)
  88. //printf("[%d %d] %d\n",c[i].left,c[i].right,c[i].val);//自己测试的。。
  89. }
  90. }
  91. }
  92. return 0;
  93. }



                
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小舞很执着/article/detail/918458
推荐阅读
相关标签
  

闽ICP备14008679号