当前位置:首页 > 初赛 > 正文内容

信息学奥赛知识点(十四)----指针

亿万年的星光2年前 (2024-06-13)初赛1584

3.1 定义

指针就是地址。

指针变量定义形式:  类型说明符  *变量名     例如:int  *a;

含义:定义了一个int *类型变量,名称为a。(只能存储int *类型)

注意:int *类型和int 类型不一样。


3.2 指针的赋值

实际操作中,&”符号表示“取地址符”。(区别与&&和按位与&,使用场景不同)。比如下面的代码:

1.  #include<iostream>

2.  #include<cstdio>

3.  using namespace std;

4.  int main() {

5.   int a=3;

6.   int *p=NULL;

7.   p=&a;

8.   cout<<"a的值"<<a<<endl;  //3

9.   cout<<"p的值"<<p<<endl;  //0x22fe34

10.  cout<<"*p的值"<<*p<<endl; //3

11.  return 0;

12. }

其中,第7行的“&”表示取变量a的地址,赋值给p变量,而p是指针类型,可以保存地址。

scanf读取数据的时候,也会写作scanf(“%d”,&a); 这里面的&”也是取地址符号。

10行的结果是3,也就是a的值,这里可以这样理解:因为pint *类型,*p等价于*(int *),这里可以“负负得正”的思想来记录结果,也就是指向了int *这个指针所指向的变量。

3.3 指针与数组

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

1.  #include<iostream>

2.  #include<cstdio>

3.  using namespace std;

4.  int main() {

5.   int a[10];

6.   for(int i=0; i<5; i++) {

7.    scanf("%d",a+i); 

8.   }

9.   for(int i=0; i<5; i++) {

10.   printf("%d ", *(a+i)); 

11.  }

12.  return 0;

13. }


1.  #include<iostream>

2.  #include<cstdio>

3.  using namespace std;

4.  int main() {

5.   int a[10]= {1,2,3,4,5};

6.   int *pa=a;

7.   cout<<a[0]<<endl; //结果是1

8.   cout<<pa<<endl;   //0x70fdf0

9.   cout<<*pa<<endl;  //结果是1

10.  pa++;

11.  cout<<pa<<endl; //0x70fdf4

12.  cout<<*pa<<endl;  //2

13.  return 0;

14. }



3.4 指针与函数

//不能完成交换的例子

1.  #include<iostream>

2.  #include<cstdio>

3.  #include<cstring>

4.  using namespace std;

5.  void swap(int x, int y) {

6.   int a=x;

7.   x=y;

8.   y=a;

9.   cout<<x<<" "<<y<<endl; // 4 3

10. }

11. int main() {

12.  int a=3,b=4;

13.  swap(a,b);

14.  cout<<a<<" "<<b<<endl;  // 3 4

15.  return 0;


//能完成交换的例子

1.  #include<iostream>

2.  #include<cstdio>

3.  #include<cstring>

4.  using namespace std;

5.  void swap(int &x, int &y) {

6.   int a=x;

7.   x=y;

8.   y=a;

9.   cout<<x<<" "<<y<<endl; // 4 3

10. }

11. int main() {

12.  int a=3,b=4;

13.  swap(a,b);

14.  cout<<a<<" "<<b<<endl;  // 4 3

15.  return 0;


//指针作为参数的例子1

1.  #include<iostream>

2.  #include<cstdio>

3.  #include<cstring>

4.  using namespace std;

5.  void swap(int *x, int *y) {

6.   int t =*x;

7.   *x= *y;

8.   *y=t;

9.   cout<<*x<<" "<<*y<<endl; // 4 3

10. }

11. int main() {

12.  int a=3,b=4;

13.  swap(&a,&b);

14.  cout<<a<<" "<<b<<endl;  // 4 3

15.  return 0;



//指针作为参数的例子2

1.  #include<iostream>

2.  #include<cstdio>

3.  #include<cstring>

4.  using namespace std;

5.  void swap(int *x, int *y) {

6.   *x=5;

7.  }

8.  int main() {

9.   int a=3,b=4;

10.  swap(&a,&b);

11.  cout<<a<<" "<<b<<endl;  //5 4

12.  return 0;

13. }


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

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

分享给朋友:

相关文章

NOIP2012年普及组初赛题目及答案分析

NOIP2012年普及组初赛题目及答案分析

一、单项选择题(共20题,每题1.5分,共计30分;每题且仅有一个正确选项)1.计算机如果缺少(A ),将无法正常启动。A.内存       ...

NOIP2009年普及组初赛题目及答案解析

NOIP2009年普及组初赛题目及答案解析

一、单项选择题(共20题,每题1.5分,共计30分。每题有且仅有一个正确答案。)1、 关于图灵机下面的说法哪个是正确的:( D)A.图灵机是世界上最早的电子计算机。B.由于大量使用磁带操作,图灵机运行...

信息学奥赛知识点(十)----计算机安全知识

计算机安全是中最重要的是存储数据安全,其面临的主要威胁包括:计算机病毒、非法访问、计算机电磁辐射、硬件损坏等。计算机病毒是附在计算机软件中的隐蔽的小程序,它和计算机其他程序一样,但会破坏正常的程序和数...

NOIP2011年普及组初赛题目及答案分析

NOIP2011年普及组初赛题目及答案分析

一、单项选择题(共 20 题,每题 1.5 分,共计 30 分。每题有且仅有一个正确选项。)1、在二进制下,1101001 + (  B ) = 1110110。A、1011&nb...

NOIP2008年普及组初赛题目答案及解析

NOIP2008年普及组初赛题目答案及解析

一、 单项选择题 (共20题,每题1.5分,共计30分。每题有且仅有一个正确答案.)。1.微型计算机中,控制器的基本功能是(  A )。A. 控制机器各个部件协...

信息学奥赛知识点(四)----计算机语言

信息学奥赛知识点(四)----计算机语言

程序是一系列的操作步骤,计算机程序就是由人事先规定的计算机完成某项工作的操作步骤,每一个步骤具体内容由计算机能够理解的指令来描述,这些指令告诉计算机“做什么”和“怎么做”  &nb...