64,642
社区成员
发帖
与我相关
我的任务
分享
#include <iostream.h>
void initialize(long *head,long *tail)
{
long *p=head;
int i;
for(i=0;i<1000000;i++)
{
*p=i;
p++;
}
tail=--p;
}
main()
{
long *head=new long[1000000];
long *tail;
long *p=head;
long *pn=head;
int n=0;
cout<<"Input N please:";
cin>>n;
initialize(head,tail);
while (p!=tail&&n>0)
{
p++;
n--;
}
while (p!=tail)
{
p++;
pn++;
}
cout<<"倒数第n个元素是:"<<*pn;
return 0;
}
#include <iostream.h>
void initialize(long *head)
{
long *p=head;
int i;
for(i=0;i <1000;i++)
{
*p=i;
p++; //这里对p操作了1000个long单元,但传进来的head只申请了一个long单元
cout < <*p < <endl; //这一行应该放到上一行前面吧,要不最后一次 i=999时访问越界了
}
}
main()
{
long *head=new long; //这里只申请了一个long内存,应该改成 long *head = new long[1000];
long *p=head;
initialize(head);
cout < <*p;
return 0;
}