编写一个程序,初始化一个double类型的数组,然后把该数组的内容拷贝至3个其他数组中(在 main()中声明这4个数组)。第1个函数使用带数组表示法的函数进行第1份拷贝。第2个函数使用带指针表示法和指针递增的函数进行第2份拷贝。 把目标数组名、源数组名和待拷贝的元素个数作为前两个函数的参数。第3个函数以目标数组名、源数组名和指向源数组最后一个元素后面的元素的指针。也就是说,给定以下声明,则函数调用如下所示:
double source[5] = {1.1, 2.2, 3.3, 4.4, 5.5};
double target1[5];
double target2[5];
double target3[5];
copy_arr(target1, source, 5);
copy_ptr(target2, source, 5);
copy_ptrs(target3, source, source + 5)
#include#include #include using namespace std; //方式一, 使用数组传值 void copy_arr(double target1[], double source[], int len) { for (int i = 0; i < len; i++) { target1[i] = source[i]; } } //方式二, 使用指针自增 void copy_ptr(double *target2, double *source, int len) { for (int i = 0; i < len; i++) { *(target2 ++) = *(source + i); } } //方式三, 使用指针指向开始, 结束作为条件 //target3:目标数组, source_start:数组起始, source_end:数组尾部 void copy_ptrs(double *target3, double *source_start, double *source_end) { while (source_start < source_end) { *(target3++) = *(source_start++); } } int main(void) { double source[5] = { 1.1, 2.2, 3.3, 4.4, 5.5 }; int len = sizeof(source) / sizeof(source[0]); //数组长度 //把source数组的数据, 用不同的方式拷贝到以下三个数组中 double target1[5]; double target2[5]; double target3[5]; //方式一, 使用数组 copy_arr(target1, source, len); cout << "target1: "; for (int i = 0; i < len; i++) { cout << target1[i] <<" "; } cout << endl; //方式二, 使用指针 cout << "target2: "; copy_ptr(target2, source, len); for (int i = 0; i < len; i++) { cout << *(target2+i) << " "; } cout << endl; //方式三, 使用指针指向开始, 结束作为条件 cout << "target3: "; copy_ptrs(target3, source, source + len); for (int i = 0; i < len; i++) { cout << *(target3 + i) << " "; } cout << endl; system("pause"); return 0; }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)