C语言学习记录(十二)——指针与数组及字符串

文章目录


前言

一个学习嵌入式的小白~ 有问题评论区或私信指出~


提示:以下是本篇文章正文内容,下面案例可供参考

一、指针和数组

  • 在C语言中 ,数组的指针是指数组在内存中的起始地址,数组元素的地址是指数组元
    素在内存中的起始地址。
  • 一维数组的数组名为一维数组的指针(起始地址)

例如:

c 复制代码
		double x[8]; //x为数组的起始地址
		double *p;
		p = x;
		

设指针变量px的地址值等于数组指针x(即指针变量px指向数组的首元素),则:

x[i] 、 (px+i)、(x+i) 和px[i]具有完全相同的功能:访问数组的第i+1个数组元素

int a[10], *p ; p=a;

p[i] <==> *(p+i)

  • 注意:
    • 指针变量和数组在访问数组中元素时,一定条件下其使用方法具有相同的形式,因为
      指针变量和数组名都是地址量
    • 但指针变量和数组的指针(或叫数组名)在本质上不同,指针变量是地址变量,而数
      组的指针是地址常量

数组名是地址常量

p++ ,p-- (对)

a++, a-- (错)

a+1 ,*(a+2) (对)
题目:数组反序存放

c 复制代码
#include <stdio.h>

void swap(int *p1,int *p2);//交换函数
void swaparr(int arr[],int lenth);//数组为形参
void swapprr(int *arr,int lenth);//指针为形参

int main()
{
	int arr[10];
	for(int i = 0;i<10;i++)//循环输入数组中的元素
	{
		scanf("%d",&arr[i]);
	}
	
	swapprr(arr,10);//进行数组反序
	
	for(int i = 0;i<10;i++)//遍历反序之后的数组
	{
		printf("%d ",arr[i]);
	}
	return 0;
	}
void swap(int *p1,int *p2)//交换函数
{
	int temp;
	temp = *p1;
	*p1 = *p2;
	*p2 = temp;
}
void swaparr(int arr[],int lenth)反序函数
{
	for(int i=0;i<=((lenth-1)/2);i++){
		swap(&arr[i],&arr[lenth-1-i]);
	}
}	 

void swapprr(int *arr,int lenth)
{
	for(int i=0;i<=((lenth-1)/2);i++){
		swap((arr+i),(arr+lenth-1-i));
	}
}

二、指针和二维数组

多维数组就是具有两个或两个以上下标的数组

在C语言中 ,二维数组的元素连续存储,按行优先存

题目:一级指针遍历二维数组

c 复制代码
#include <stdio.h>
#include <stdlib.h>

int main()
{
    int arr[][3] = {{1,2,3},{4,5,6},{7,8,9}};
    int *p,i;
    p = arr;
    for(i = 0;i < 9;i++)
    {
        printf("%d ",*(p+i));
    }
    return 0;

}

可以把二维数组看作由多个一维数组组成。

比如ina a[3][3] ,含有三个元素,a[0],a[1],a[2]

元素a[0],a[1],a[2]都是一维数组名

二维数组名代表数组的起始地址,数组名加1,是移动一行元素。因此,二维数组名常被

称为行地址。

行指针(数组指针)

存储行地址的指针变量,叫做行指针变量,形式如下:

  • <存储类型> <数据类型> (*<指针变量名>){ 表达式n };
  • 例如:
c 复制代码
		int  a[2][3] ;   int (*p)[3];

方括号中的常量表达式表示指针加1,移动几个数据。

当用行指针操作二维数组时,表达式一般写成1行的元素个数,即列数。

题目:使用行指针表示二维数组的某个元素

c 复制代码
#include <stdio.h>
#include <stdlib.h>

int main()
{
    int arr[][3] = {{1,2,3},{4,5,6},{7,8,9}};
    int (*p)[3],i,j;
    p = arr;
    for(i = 0;i < 3;i++)
        for(j = 0;j < 3;j++)
            printf("%d ",*(*(p+i)+j));

    return 0;

}

三、 字符指针和字符串

  • C语言通过使用字符数组来处理字符串
  • 通常,我们把char数据类型的指针变量称为字符指针变量。字符指针变量与字符有着
    密切关系,他也被用来处理字符串。
  • 初始化字符指针是把内存中字符串的首地址赋予指针,并不是把该字符串复制到指针
    中。
c 复制代码
	char  str[] = "Hello World";
	char *p  = str;
  • 在C语言编程中,当一个字符指针指向一个字符串常量时,不能修改指针指向的对象
    的值
c 复制代码
	char *p = "Hello World";  
	*p  = 'h';

题目:不使用任何字符串函数,实现字符串函数连接功能

c 复制代码
#include <stdio.h>
#include <stdlib.h>

int Mystrlen(char *p);
int main()
{
    char a[100],b[100],c[100];
    char *p;
    p = c;
    int l1,l2;
    printf("please input first string:");
    gets(a);
    printf("please input conented string:");
    gets(b);
    l1 = Mystrlen(a);
    l2 = Mystrlen(b);
    for(int i = 0 ; i<(l1+l2) ; i++)
    {
        if(i < l1)
        {
            p[i] = a[i];
        }
        else
        {
            p[i] = b[i-l1];
        }
        if( i == (l1+l2-1))
        {
            p[i+1] = '\0';
        }
    }
    printf("%s\n",c);
    return 0;
}
int Mystrlen(char *p)
{
    int n = 0;
    for(int i = 0 ; i < 100 ; i++)
    {
        if(p[i] != '\0')
        {
            n++;
        }
        else
        {
            return n;
        }
    }
    return n;
}

四、指针数组

所谓指针数组是指由若干个具有相同存储类型和数据类型的指针变量构成的集合

指针数组的一般说明形式:

  • <存储类型 > <数据类型> *<指针数组名> [<大小>]
  • 指针数组名表示该指针数组的起始地址
    声明一个指针数组
c 复制代码
double *pa2[2] , a[2][3];

把一维数组a[0] 和 a[1]的首地址分别赋予指针变量数组的数组元数pa[0] 和pa[1];

c 复制代码
pa[0] = a[0]; //等价于pa[0] = &a[0][0]
pa[1] = a[1]; //等价于pa[1] = &a[1][0]

此时pa[0]指向了一维数组a[0]的第一个元素,而pa[1]指向了一维数组a[1]的第一个元素。

题目:使用指针数组处理二维数组,求出二维数组所有元素的和。

c 复制代码
#include <stdio.h>
#include <stdlib.h>


int main()
{
    int arr[][3] = {{1,2,3},{4,5,6},{7,8,9}};
    int *pa[3];
    int i,j,sum = 0;
    for(i = 0;i < 3;i++)
    {
        pa[i] = arr[i];
    }
    for(i = 0;i < 3;i++)
        for(j = 0;j < 3;j++)
            sum += *(pa[i]+j);
    printf("%d",sum);
    return 0;
}
相关推荐
岁岁岁平安22 分钟前
spring学习(spring-DI(字符串或对象引用注入、集合注入)(XML配置))
java·学习·spring·依赖注入·集合注入·基本数据类型注入·引用数据类型注入
武昌库里写JAVA25 分钟前
Java成长之路(一)--SpringBoot基础学习--SpringBoot代码测试
java·开发语言·spring boot·学习·课程设计
qq_5895681031 分钟前
数据可视化echarts学习笔记
学习·信息可视化·echarts
yuanbenshidiaos1 小时前
C++----------函数的调用机制
java·c++·算法
唐叔在学习1 小时前
【唐叔学算法】第21天:超越比较-计数排序、桶排序与基数排序的Java实践及性能剖析
数据结构·算法·排序算法
兔C1 小时前
微信小程序的轮播图学习报告
学习·微信小程序·小程序
海海不掉头发1 小时前
苍穹外卖-day05redis 缓存的学习
学习·缓存
ALISHENGYA2 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(switch语句)
数据结构·算法
chengooooooo2 小时前
代码随想录训练营第二十七天| 贪心理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和
算法·leetcode·职场和发展
jackiendsc2 小时前
Java的垃圾回收机制介绍、工作原理、算法及分析调优
java·开发语言·算法