当前位置:首页 > C++目录 > 正文内容

指针(二):指针与数组

亿万年的星光5年前 (2021-08-10)C++目录20587

1.指针与数组的关系

    指向数组的指针变量称为数组指针变量。“数组是内存上一块连续的空间”。数组名就是这块连续空间的首地址。


2.指针指向数组


    一开始的数组定义与输出:

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a[10];
	for(int i=0;i<5;i++){
		cin>>a[i];
	}
	for(int i=0;i<5;i++){
		cout<<a[i]<<" ";
	}
	return 0;
}

指针操作也可以输入数据:

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a[10];
	for(int i=0;i<5;i++){
		scanf("%d",a+i); //本来写成scanf("%d",&a[i]); 
	}
	for(int i=0;i<5;i++){
		printf("%d ", *(a+i));  //
	}
	return 0;
}

上面这个操作,本来scanf("%d",&a)写法,其中&是取地址符,a是数组名,本来就表示数组空间的首地址,所以可以直接用。注意,这个地方不能用cin。

数组指向指针操作:

我们可以定义指针变量,让它来指向数组名。

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a[10];
	int *p=a;  
	for(int i=0;i<5;i++){
		scanf("%d",p+i); //本来写成scanf("%d",&a[i]); 
	}
	for(int i=0;i<5;i++){
		printf("%d ", *(p+i)); 
	}
	return 0;
}

2.指针的加减

指针也是变量,可以加减。

#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int a[10]={1,2,3,4,5};
	int *pa=a;  
	cout<<a[0]<<endl; //结果是1 
	cout<<pa<<endl;   //0x70fdf0
	cout<<*pa<<endl;  //结果是1
	
	pa++;
	cout<<pa<<endl; //0x70fdf4
	cout<<*pa<<endl;  //2
	
	pa=pa+2;
	cout<<pa<<endl; //0x70fdfc
	cout<<*pa<<endl;  //4
	
	pa--;
	cout<<pa<<endl; //0x70fdf8
	cout<<*pa<<endl;  //3 
	return 0;
}


其他高级操作:

(1)数组名作为指针参数传递

#include <iostream>
using namespace std;

// 方式1:数组指针 + 大小参数
void printArray(int* arr, int size) {
    for (int i = 0; i < size; i++) {
        cout << arr[i] << " ";
    }
    cout << endl;
}


int main() {
    int arr[5] = {1, 2, 3, 4, 5};

    // 数组名自动退化为指针
    printArray(arr, 5);
    
    return 0;
}




(2)使用容器(推荐)

#include <iostream>
#include <vector>
using namespace std;
// 使用 vector
void printVector(const vector<int>& vec) {
	for (size_t i = 0; i < vec.size(); i++) {
		cout << vec[i] << " ";
	}
	cout << endl;
}
int main() {
	vector<int> vec;
	vec.push_back(1);
	vec.push_back(2);
	vec.push_back(3);

	printVector(vec);

	return 0;
}


这里加不加const的区别是:加入const后,原数组不能被修改,是只读状态,如果要赋值会报错


    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:

    相关文章

    【算法】单链表的一些操作(存取、查找、取出、插入、删除)

    一、单链表结构的建立与输出#include<iostream> using namespace std; struct Node{ int ...

    【数据结构】栈—表达式括号匹配

    【数据结构】栈—表达式括号匹配

    【题目描述】假设一个表达式有英文字母(小写)、运算符(+,—,*,/)和左右小(圆)括号构成,以“@”作为表达式的结束符。请编写一个程序检查表达式中的左右圆括号是否匹配,若匹配,则返回“YES”;否则...

    C++中的宏

    一、预处理和编译器    首先,预编译器就是在编译器之前运行,换句话说,预编译器根据程序员的指示,决定实际要编译的内容。预编译器编译指令都以 # 开头。例如:1...

    【题解】玩具

    【题目描述】商店正在出售蒜头君最喜欢的系列玩具,在接下来的 " 周中,每周会出售其中的一款,同一款玩具不会重复出现。由于是蒜头君最喜欢的系列,他希望尽可能多地购买这些玩具,但是同一款玩具蒜头...

    Code::Blocks下载安装教程

    Code::Blocks下载安装教程

    Code::Blocks 是一款免费、开源且跨平台的 C/C++ 集成开发环境。它支持 Windows、Linux 和 macOS 等多种操作系统,核心特点是轻量快速、纯专注于 C/C++ 开发,并内...

    最小生成树(1)

    最小生成树(1)

    一、定义一个有 n 个结点的连通图的生成树是原图的极小连通子图,且包含原图中的所有 n 个结点,并且有保持图连通的最少的边。最小生成树可以用kruskal(克鲁斯卡尔)算法或prim(普里姆)算法求出...