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

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

亿万年的星光11个月前 (06-13)初赛852

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. }


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

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

分享给朋友:

相关文章

信息学奥赛知识点(九)----因特网概述

英特网(Internet),它所采用的网络协议是TCP/IP协议。它是因特网的核心技术。TCP/IP协议,具体地说就是传输控制协议和网际协议。其中,TCP协议用于负责网上信息的正确传输,而IP协议则是...

信息学奥赛知识点(二)----计算机结构及硬件

信息学奥赛知识点(二)----计算机结构及硬件

一、计算机系统构成计算机硬件计算机硬件主要由五大部分构成:运算器、控制器、存储器、输入设备、输出设备。其中运算器和控制器都在CPU中。中央处理器(CPU)(1)有运算器、控制器和一些寄存器组成运算器进...

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

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

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

信息学奥赛知识点(十五)----链表

信息学奥赛知识点(十五)----链表

4.1 基本概念(1)用来存储数据变量叫做数据域。(2)用来存“直接后继(前趋)元素的地址”的指针叫做指针域。(3)数据域和指针域构成的元素叫做结点。(4)”->” 箭头运算是结构体指针访问其指...

信息学奥赛知识点(八)----计算机网络

信息学奥赛知识点(八)----计算机网络

一、网络的定义所谓计算机网络,就是利用通信线路和设备,把分布在不同地理位置上的多台计算机连接起来。计算机网络是现代通信技术与计算机技术相结合的产物。网络中的计算机与计算机之间的通信依靠协议进行。协议是...

2019年CSP-J 初赛题目及答案解析

2019年CSP-J 初赛题目及答案解析

扫码关注下面微信公共号,发送“CSPJ2019”获取文章答案查看详细解题过程:原版初赛题目下载链接:CSP-J相关资料 - 青少年编程知识记录 (codecoming.com)答案:解析:2019年普...