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

指针(二):指针与数组

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

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后,原数组不能被修改,是只读状态,如果要赋值会报错


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

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

    分享给朋友:

    相关文章

    混合背包

    1.问题定义:混合背包问题是经典背包问题的一个变种,其中物品的类型不单一,而是混合了以下三种类型:01 背包物品:每种物品最多只能选一次。完全背包物品:每种物品可以选择无限次。多重背包物品:每种物品有...

    数组的不确定长度输入

    0.前言我们在学习数组的时候一般都会告诉你数组的长度,然后for循环去遍历。但是有一类问题是没有n的,也就是没有告诉长度的。1.方法第一种:(数组)#include<iostream>...

    【算法】分治算法

    前言所谓分治算法就是指分而治之,即将较大规模的问题分解成几个较小规模的问题,通过对较小问题的求解达到对整个问题的求解。当我们将问题分解成两个较小问题求解时的分治方法称为二分法。比如,我们玩过最简单的猜...

    【题解】采药的最短路径

    【题目描述】少年李逍遥的婶婶病了,王小虎介绍他去一趟仙灵岛,向仙女姐姐要仙丹救婶婶。孝顺的李逍遥闯进了仙灵岛,克服了千险万难来到岛的中心,发现仙药摆在了迷阵的深处。迷阵由M×N个方格组成,有的方格内有...

    CSP-J2021年普及组复赛T4——小熊的果篮

    【题目描述】    小熊的水果店里摆放着一排 n 个水果。每个水果只可能是苹果或桔子,从左到右依 次用正整数 1、2、3、……、n 编号。连续排在一起的同一种...

    【图】并查集—基本概念

    【图】并查集—基本概念

    1.引入    对于一个集合S={a1, a2, …, an-1, an},我们还可以对集合S进一步划分: S1,S2,…,Sm-1,Sm,我们希望能够快速确定...