c++ copy函数的起始,delete数组出错

有两个问题

1.据我所知
copy(buf.begin(), buf.end(), nums.begin());
表示将buf中的元素赋值给nums。
假如buf数组有3个元素 int*p=buf;
为什么是copy(p,p+3,nums);
而不是copy(p,p+2,nums);
指针p到p+3都经过了四个元素了呀
2.程序运行时,delete一个数组出现错误,弹出一个delete_scalar.cpp
已在 Project6.exe 中执行断点指令(__debugbreak()语句或类似调用
去掉delete恢复正常,求原因

//改变一维数组长度
#include
#include
using namespace std;
int arr[] = { 1,2,3 };
template<class T>
int ChangeArray(T* p, int newlength, int oldlength)
{
    T* q = new int[newlength];
    int min1 = min(newlength, oldlength);
    if (newlength < 0)
    {
        cout << "非法输入";
        return 0;
    }

    else {
        copy(arr, arr + min1 , q);
    }
    for (int i = 0; i < min1; i++)
    {
        cout << *(q + i)<int main()
{
    
    ChangeArray(arr, 2, 3);
    delete[]arr;
    return 0;

}


不胜感激

delete得和new配对啊,arr又不是new创建的,你delete干啥呢???
函数传递的是指针,在函数内虽然new创建了p,但这个p已经和arr一毛钱关系也没有了,是不会修改外部的arr指针地址的。所以你得在函数内进行dlete p才可以
你都说了,copy(buf.begin(), buf.end(), nums.begin()); 也就是说,第二个参数需要时end,而不是最后一个有效元素,所以应该是p+3而不是p+2,因为p+2是有效元素,p+3是end

参考GPT和自己的思路:

  1. 在copy函数中,第二个参数p+3表示一个迭代器,指向数组中第四个元素的后面一个位置,因此会将buf中的所有元素都赋值给nums,而不是只有前两个元素。

  2. 在程序中,arr是一个静态数组,不能使用delete操作删除内存,应该使用delete[]操作,因为该数组是动态分配的。所以将delete[]arr改为delete[]q即可正常运行。另外,在ChangeArray函数中,返回值类型应该为T*,而不是int。