C语言进阶版第8课—指针(2)

2024-09-08 05:52
文章标签 语言 进阶 指针

本文主要是介绍C语言进阶版第8课—指针(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1. 数组名的理解
  • 2. 指针访问数组
  • 3. 一维数组传参本质
  • 4. 冒泡排序
  • 5. 二级指针
  • 6. 指针数组
  • 7. 指针数组模拟二维数组

1. 数组名的理解

  • sizeof(数组名)— 这里的数组名代表整个数组,计算的也是整个数组的大小
  • &数组名 — 这里的数组名代表是整个数组,取出的是整个数组的地址
  • 除了以上两种,其他任何地方使用数组名,数组名都表示首元素的地址
//数组名的理解
#include <stdio.h>
int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };printf(" arr = %p\n", arr);        // arr  ---> 数组首元素地址printf("arr[0]=%p\n", &arr[0]);   //&arr[0]---> 数组首元素地址printf(" &arr =%p\n", &arr);     //  &arr  ---> 整个数组的地址,不过指向的是数组首元素地址printf("--------------------------\n");printf(" arr+1 =  %p\n", arr+1);printf("&arr[0]+1=%p\n", &arr[0]+1);printf(" &arr+1 = %p\n", &arr+1);return 0;
}

  arr&arr[0]都是指向数组首元素地址,两者等价,只是不同的写法,而&arr虽然也指向数组首元素地址,但它代表的是整个数组的地址,因此&arr+1代表跳过整个数组的地址,&arr&arr+1应该相差4*10个字节
在这里插入图片描述
在这里插入图片描述

2. 指针访问数组

在这里插入图片描述
在这里插入图片描述

3. 一维数组传参本质

在这里插入图片描述
在这里插入图片描述
  数组传参本质上传递的是数组首元素地址,另外一维数组传参时,形参部分可写成数组形式,大小可忽略不写,也可写成指针形式

#include <stdio.h>
void test(int arr[])      //也可写成void test(int* p)
{printf("hehe\n");
}int main()
{int arr[10] = { 0 };test(arr);return 0;
}

4. 冒泡排序

  • 问题描述:给一组整型数组,对其排序
  • 核心思想:两两相邻元素进行比较

在这里插入图片描述  冒泡排序就是第一个元素与其他九个元素对比,并按照升序或降序的方式进行相应的交换,每趟都能确定待排序的一个元素

//冒泡排序(简易版)
#include <stdio.h>
void bubble_simple(int arr[], int sz)
{for (int i = 1; i < sz; i++){for (int j = 0; j < sz - i; j++){if (arr[j] > arr[j + 1]){int tmp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = tmp;}printf("第%d趟排序中第%d次对比/交换:", i,j+1);for (int n = 0; n < sz - i; n++){printf("%d ", arr[n]);}printf("\n");}printf("------------------------------------------\n");printf("第%d趟排序的结果:",i);for (int k = 0; k < sz; k++){printf("%d ", arr[k]);}printf("\n");printf("------------------------------------------\n");}
}
int main()
{int arr[10] = { 9,4,5,7,2,1,3,8,6,10 };int sz = sizeof(arr) / sizeof(arr[0]);bubble_simple(arr, sz);return 0;
}

在这里插入图片描述
在这里插入图片描述

  • 冒泡排序优化代码
  • 有序则跳出
//冒泡排序(优化)
#include <stdio.h>
void bubble_sort(int arr[], int sz)
{for (int i = 1; i < sz; i++){int flag = 1;    //flag用来判断数组是否有序(1代表有序)for (int j = 0; j < sz - i; j++){if (arr[j] > arr[j + 1]){flag = 0;  //发生交换代表无序int tmp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = tmp;}}if (flag == 1)break;         //如果这趟已经有序则跳出循环printf("------------------------------------------\n");printf("第%d趟排序的结果:", i);for (int k = 0; k < sz; k++){printf("%d ", arr[k]);}printf("\n");printf("------------------------------------------\n");}
}
int main()
{int arr[10] = { 9,4,5,7,2,1,3,8,6,10 };int sz = sizeof(arr) / sizeof(arr[0]);bubble_sort(arr, sz);printf("最终的排序结果>:");for (int i = 0; i < sz; i++){printf("%d ", arr[i]);}return 0;
}

在这里插入图片描述

5. 二级指针

  • 二级指针用来存储一级指针变量的地址

在这里插入图片描述

//二级指针
#include <stdio.h>
int main()
{int a = 10;printf("a的地址>:%p\n", &a);int* p = &a;printf("a的地址>:%p\n", p);   //p = &aprintf("p的地址>:%p\n", &p);  printf("*p = %d\n", *p);      //*p = aint* * pp = &p;**pp = 20;printf("p的地址>:%p\n", pp); //pp = &pprintf("pp的地址>:%p\n", &pp);printf("* *pp = %d\n", **pp); // *pp = p, **pp == *(*pp) == *p == areturn 0;
}

在这里插入图片描述
在这里插入图片描述

6. 指针数组

  • 存放指针的数组

在这里插入图片描述

7. 指针数组模拟二维数组

  • 在讲解之前,我们先来回忆一下二维数组

在这里插入图片描述
在这里插入图片描述
  arr与&arr[0]都是二维数组首元素地址,则arr+1和&arr[0]+1都是二维数组的第二个元素,跳过4*4=16个字节,图中arr和&arr[0]对应地址后两位B4==11*16+4*1=180,arr+1和&arr[0]+1则对应C4==12*16+4*1=196,两者刚好差16字节

  • 指针数组模拟二维数组
    在这里插入图片描述

这篇关于C语言进阶版第8课—指针(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147304

相关文章

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

Go语言利用泛型封装常见的Map操作

《Go语言利用泛型封装常见的Map操作》Go语言在1.18版本中引入了泛型,这是Go语言发展的一个重要里程碑,它极大地增强了语言的表达能力和灵活性,本文将通过泛型实现封装常见的Map操作,感... 目录什么是泛型泛型解决了什么问题Go泛型基于泛型的常见Map操作代码合集总结什么是泛型泛型是一种编程范式,允

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3