POJ 2828第一个线段树

开始接触到数据结构里的线段树了,这块比较新颖,搞了好久白书的那两个题,无奈实在太冗长的代码了,完全搞不懂,在网上找来了http://blog.csdn.net/liuqiyao_01/article/details/9712191

里的习题总结挑了这题做了一下,马上弄懂了基础的单点更新的线段树的写法,包括建树和update的写法。学习线段树我还参考了这篇博文 http://blog.csdn.net/zip_fan/article/details/46775633



这题的思路就是最后一步肯定是最后达到的位置,那么最后一步的val所对应的位置肯定是确定,那么可以进行倒推,在完成最后一步之后那么倒数第二步也是确定的,依次进行即可。然后因为线段树的更新特性,当一个叶子结点发生变化,其所在的对应的在内的祖先也会发生变化,然后就对后一次的update产生了影响。

直接贴上这题的代码了:

#include<cstdio>
#include<cstring>
#include<algorithm>

using namespace std;

#define lson l, m, rt<<1
#define rson m+1, r, rt<<1|1
#define mid int m = (l + r)>>1
const int maxn=200010;
int n,m;
int pos[maxn],val[maxn],tmp[maxn<<2];
struct node
{
    int l,r;
    int sum;
}a[maxn<<2];

void build(int l,int r,int rt)
{
    a[rt].l=l;
    a[rt].r=r;
  a[rt].sum=r-l+1;
  if(a[rt].l==a[rt].r)
    return ;
  mid;
  build(lson);
  build(rson);

}

void update(int pos,int val,int l,int r,int rt)
{
  if(l==r)
  {
      tmp[l]=val;
      a[rt].sum--;
      return ;
  }
  mid;
  if(pos<=a[rt<<1].sum) update(pos,val,lson);
  else update(pos-a[rt<<1].sum,val,rson);
  a[rt].sum=a[rt<<1].sum+a[rt<<1|1].sum;

}

void print()
{
   for(int i=l;i<=n;i++)
   {
       if(i==1)
       printf("%d",tmp[i]);
       else
        printf(" %d",tmp[i]);
   }
}

/*用这种写法的话main里的print(1,n,1)即可,然后update里的tmp[rt]=val即可
void print(int l, int r, int rt)
{
    if(l == r){printf("%d ",tmp[rt]);return;}
    mid;
    print(lson);
    print(rson);
}

*/


int main()
{
    while(scanf("%d",&n)!=EOF)
    {

     for(int i=0;i<n;i++)
     {
         scanf("%d%d",&pos[i],&val[i]);
     }
     build(1,n,1);
     for(int i=n-1;i>=0;i--)
     {
         update(pos[i]+1,val[i],1,n,1);
     }
     print();
        printf("\n");
    }
    return 0;
}


Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值