ando_ando 2021-09-14 18:11 采纳率: 100%
浏览 27
已结题

关于vector<int>c(N)影响地址的问题

一道离散化的题目 发现提前定长

vector<int> c(N)

时,
lower_bound(c.begin(),c.end(),num)-c.begin()的位置会偏移一位,不明白原理
而不加(N)就不会偏移
全代码如下(标准离散化模板):

#include <bits/stdc++.h>
using namespace std;

#define N 100005
int main(){
    ios::sync_with_stdio(false);
    cin.tie(0);
    int h,w,n,x,y,maa,mab;
    cin >> h >> w >> n;
    int a[N],b[N];
    vector<int>c,d;
    for(int i=1;i<=n;i++){
        cin >> a[i] >> b[i];
        c.push_back(a[i]);
        d.push_back(b[i]);
    }
    sort(c.begin(),c.end());
    sort(d.begin(),d.end());
    c.erase(unique(c.begin(),c.end()),c.end());
    d.erase(unique(d.begin(),d.end()),d.end());
    for(int i=1;i<=n;i++){
        cout << lower_bound(c.begin(),c.end(),a[i])-c.begin()+1 << " ";
        cout << lower_bound(d.begin(),d.end(),b[i])-d.begin()+1 << endl;    
    }
    return 0;
}


  • 写回答

1条回答 默认 最新

  • 急速光粒 2021-09-14 18:26
    关注

    提前定长N会创建最大数量的vector,而不是cin输入的小n个元素,end-begin肯定不一样的。有帮助请采纳谢谢!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月27日
  • 已采纳回答 9月19日
  • 创建了问题 9月14日

悬赏问题

  • ¥15 前端echarts坐标轴问题
  • ¥15 CMFCPropertyPage
  • ¥15 ad5933的I2C
  • ¥15 请问RTX4060的笔记本电脑可以训练yolov5模型吗?
  • ¥15 数学建模求思路及代码
  • ¥50 silvaco GaN HEMT有栅极场板的击穿电压仿真问题
  • ¥15 谁会P4语言啊,我想请教一下
  • ¥15 这个怎么改成直流激励源给加热电阻提供5a电流呀
  • ¥50 求解vmware的网络模式问题 别拿AI回答
  • ¥24 EFS加密后,在同一台电脑解密出错,证书界面找不到对应指纹的证书,未备份证书,求在原电脑解密的方法,可行即采纳