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 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用
  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛