拿捏c语言指针(中)

前言

书接上回 拿捏c语言指针(上)

此篇主要讲解的是指针与数组之间的爱恨情仇,跟着我的脚步一起来看看吧~


创造不易,可以帮忙点点赞吗

如有差错,欢迎指出



理解数组名

数组名是首元素地址

例外

1.sizeof(数组名),数组名表示整个数组,计算的是整个数组的大小(单位:字节)

2.&数组名,数组名表示整个数组,取出的是整个数组的地址

让他们分别+1,得到的结果

指针访问数组

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

arr[i]==*(arr+i)   arr与i交换了后  *(i+arr)==i[arr]


一维数组传参的本质

一维数组传参传的不是整个数组,而是首元素的地址

如图,若是传的是整个数组,结果应该为10

一维数组传参,形参可以是数组,也可以是指针

所以,其中函数test形参int arr[]可以替换为指针形式int*arr

冒泡排序

写一个函数,对一个整数数组的数据进行排序(升序)

思想:相邻两个元素比较,不满足顺序就交换

例如有一个降序数列:

9 8 7 6 5 4 3 2 1 0    未比较

8 9 7 6 5 4 3 2 1 0    8与9比较,9后移

…… 以此类推,9分别与7、 6 ……1、 0 比较

8 7 6 5 4 3 2 1 0 9   第一轮结束

7 8 6 5 4 3 2 1 0 7与8比较,8后移

……以此类推,直到排为升序~

代码实现

#include<stdio.h>
void BubbleSort(int arr[], int sz)
{int i = 0;for (i = 0; i < sz - 1; i++){//一轮冒泡排序的过程int j = 0;for (j = 0; j < sz - 1 - i; j++){//一对数字比较if (arr[j] > arr[j + 1])//交换条件{//交换int tmp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = tmp;}}}
}
int main()
{int arr[10] = { 9,8,7,6,5,4,3,2,1,0 };int sz = sizeof(arr) / sizeof(arr[0]);BubbleSort(arr, sz);for (int i = 0; i < sz; i++){printf("%d ", arr[i]);}

优化(提高代码运行效率)

数组arr{9,0,1,2,3,4,5,6,7,8},如果按照原代码,会傻傻地排45次

我们可以增加一些判断,进而提高代码运行效率,

如图,当排完数字9时,count=9;flag==0,第一轮结束

跳出里面for循环,开始第二轮,flag又被赋值为1,即flag==1

if条件判断0与1、1与2……7与8,判断了8次条件都不满足,此时count==17;flag==1,跳出循环

代码如下:

#include<stdio.h>int count = 0;
void BubbleSort(int arr[], int sz)
{int i = 0;for (i = 0; i < sz - 1; i++){int flag = 1;//假设排好了//一轮冒泡排序的过程int j = 0;for (j = 0; j < sz - 1 - i; j++){count++;//用于计算排了几次//一对数字比较if (arr[j] > arr[j + 1])//交换条件{//交换int tmp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = tmp;flag = 0;}}if (flag == 1){break;}}
}
int main()
{int arr[10] = { 9,0,1,2,3,4,5,6,7,8};int sz = sizeof(arr) / sizeof(arr[0]);BubbleSort(arr, sz);for (int i = 0; i < sz; i++){printf("%d ", arr[i]);}printf("count=%d", count);
}

二级指针

指针变量也是变量,他也有自己地址

如图一级指针p存放的是变量a的地址,二级指针pp存放的是一级指针变量p的地址。


指针数组

存放指针的数组,是数组(数组中每个元素是指针类型)

如:int*arr[4],每个元素都是整形指针

利用指针数组模拟实现二维数组

与二维数组的区别

二维数组的每一行是连续的,而模拟实现的不是。

示意图


字符串指针

可以把字符串想象是一个字符数组,但是这个数组是不能修改的

如图,打印*p的值不是字符串,而是字符串的第一个字符

不是把字符串abcdef\0存放在p中,而是把第一个字符的地址存放在p中

示例

《剑指offer》中收录了⼀道和字符串相关的笔试题,代码如下:

#include <stdio.h>
int main()
{char str1[] = "hello bit.";char str2[] = "hello bit.";const char* str3 = "hello bit.";const char* str4 = "hello bit.";if (str1 == str2)printf("str1 and str2 are same\n");elseprintf("str1 and str2 are not same\n");if (str3 == str4)printf("str3 and str4 are same\n");elseprintf("str3 and str4 are not same\n");return 0;
}

运行结果

解释:字符数组str1和str2是可以修改的,他们分别占用不同的空间,所以str1与str2不同

常量字符串str3和str4是不可以修改的,他们占用的空间一致,所以str3与str4相同


数组指针

指向数组的指针,是指针

用于存放数组的地址,能够指向数组的指针变量

与指针数组的区别

int* p1[10]: 指针数组,p1是数组,有10个元素,每个元素的类型是int*

int (*p2)[10]: 数组指针,p2是指针,有10个元素,每个元素的类型是int


二维数组传参的本质

二维数组传参本质上传的是一维数组(二维数组的第一行)的地址

例如

利用数组指针实现一个能够打印二维数组的函数

#include<stdio.h>void Print(int(*arr)[5], int r, int c)
{for (int i = 0; i < r; i++){for (int j = 0; j < c; j++){printf("%d ", *(*(arr + i) + j));}printf("\n");}
}
int main()
{int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7} };Print(arr, 3, 5);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/259357.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#使用迭代器实现文字的动态效果

目录 一、涉及到的知识点 1.GDI 2.Thread类 3.使用IEnumerable()迭代器 二、实例 1.源码 2.生成效果&#xff1a; 一、涉及到的知识点 1.GDI GDI主要用于在窗体上绘制各种图形图像。 GDI的核心是Graphics类&#xff0c;该类表示GDI绘图表面&#xff0c;它提供将对象绘制…

在UE5中使用体积材质

在平时使用UE的材质设置时&#xff0c;经常会看见Material Domain Volume类型&#xff0c;但是却很少使用。其实该类型可以配合体积雾使用&#xff0c;并制作体积效果以弥补自带雾参数的不足。 操作流程 首先找到场景中的ExponentialHeightFog组件&#xff0c;开启体积雾Volu…

c++阶梯之类与对象(下)

前文&#xff1a; c阶梯之类与对象&#xff08;上&#xff09;-CSDN博客 c阶梯之类与对象&#xff08;中&#xff09;-CSDN博客 c阶梯之类与对象&#xff08;中&#xff09;&#xff1c; 续集 &#xff1e;-CSDN博客 1. 再谈构造函数 1.1 构造函数体赋值 在创建对象时&a…

Momentum2

攻击机 192.168.223.128 目标机 192.168.223.147 主机发现 nmap -sP 192.168.223.0/24 端口扫描 nmap -sV -A -p- 192.168.223.147 开启了22 80 端口 看一下web界面 源码&#xff0c;robots.txt ,url都观察了一下好像没什么有用信息 扫一下目录 gobuster dir -u http:…

C++面试宝典第28题:寻找丢失的数字

题目 给定一个包含n个整数的数组nums,其中nums[i]在区间[1, n]内。请找出所有在[1, n]范围内,但没有出现在nums中的数字,并以数组的形式返回结果。 示例1: 输入:nums = [4, 3, 2, 7, 8, 2, 3, 1] 输出:[5, 6] 示例2: 输入:nums = [1, 1] 输出:[2] 解析 初看这道题,…

VFH特征的使用(一)

一、SHOT特征描述符可视化 C #include <pcl/point_types.h> #include <pcl/point_cloud.h> #include <pcl/io/pcd_io.h> #include <pcl/features/normal_3d_omp.h> #include <pcl/registration/correspondence_estimation.h> #include <boo…

『 C++ 』海量数据处理

文章目录 &#x1f996; 快速找出海量数据中是否存在该整型数据&#x1f996; 有限内存情况下两个文件(海量query)中找出交集&#x1f996; 海量数据中找出只出现1次的数据&#x1f996; 有限内存情况下两个文件(整型)找出交集&#x1f996; 海量数据中找出出现次数不超过2次的…

挑战杯 YOLOv7 目标检测网络解读

文章目录 0 前言1 yolov7的整体结构2 关键点 - backbone关键点 - head3 训练4 使用效果5 最后 0 前言 世界变化太快&#xff0c;YOLOv6还没用熟YOLOv7就来了&#xff0c;如果有同学的毕设项目想用上最新的技术&#xff0c;不妨看看学长的这篇文章&#xff0c;学长带大家简单的…

5G——小区搜索流程

小区搜索流程 小区搜索目标&#xff1a;读取到SIB1. 小区搜索流程概述&#xff1a;SIB1在PDSCH信道承载&#xff0c;承载SIB1的信道在哪个位置由PDCCH告诉&#xff0c;而PDCCH的基本信息由MIB告诉&#xff0c;MIB信息由广播信道PBCH广播出去&#xff0c;物理信道解调需要解调…

vue3-组合式 API

什么是组合式 API&#xff1f; 组合式 API (Composition API) 是一系列 API 的集合&#xff0c;使我们可以使用函数而不是声明选项的方式书写 Vue 组件。它是一个概括性的术语&#xff0c;涵盖了以下方面的 API&#xff1a; 响应式 API&#xff1a;例如 ref() 和 reactive()&a…

HttpRunner自动化测试之实现参数化传递

参数化实现及重复执行 参数化测试&#xff1a;在接口测试中&#xff0c;为了实现不同组数据对同一个功能模块进行测试&#xff0c;需要准备多组测试数据对模块进行测试的过程。 在httprunner中可以通过如下方式实现参数化&#xff1a; 1、在YAML/JSON 中直接指定参数列表 2、…

【C++】C++入门

关于C是什么 C语言是结构化和模块化的语言&#xff0c;适合处理较小规模的程序。对于复杂的问题&#xff0c;规模较大的程序&#xff0c;需要高度的抽象和建模时&#xff0c;C语言则不合适。为了解决软件危机&#xff0c;20世纪80年代&#xff0c;计算机界提出了OOP(object or…

静态时序分析:SDC约束命令set_clock_latency详解

相关阅读 静态时序分析https://blog.csdn.net/weixin_45791458/category_12567571.html?spm1001.2014.3001.5482 时钟的延迟可以使用set_clock_latency命令设置&#xff0c;这里的时钟延迟包括源延迟(source latency)&#xff0c;即时钟对象到时钟源对象&#xff08;时钟定义…

Linux——网络通信TCP通信常用的接口和tcp服务demo

文章目录 TCP通信所需要的套接字socket()bind()listen()acceptconnect() 封装TCP socket TCP通信所需要的套接字 socket() socket()函数主要作用是返回一个描述符&#xff0c;他的作用就是打开一个网络通讯端口&#xff0c;返回的这个描述符其实就可以理解为一个文件描述符&a…

抖音关键词搜索爬虫,抖音API数据接口,抖音商品详情数据采集

抖音商品API接口抖音关键词搜索抖音直播间小黄车抖店商品数据采集 除了微博&#xff0c;小红书&#xff0c;抖音也是一个巨大的流量池。 除了评论&#xff0c;其实关键词搜索视频是更为常见的一个需求&#xff0c;于是上周末抽空开发了下&#xff0c;完成了 mvp。

数据结构——lesson3单链表介绍及实现

目录 1.什么是链表&#xff1f; 2.链表的分类 &#xff08;1&#xff09;无头单向非循环链表&#xff1a; &#xff08;2&#xff09;带头双向循环链表&#xff1a; 3.单链表的实现 &#xff08;1&#xff09;单链表的定义 &#xff08;2&#xff09;动态创建节点 &#…

【数据结构】链表OJ面试题5《链表的深度拷贝》(题库+解析)

1.前言 前五题在这http://t.csdnimg.cn/UeggB 后三题在这http://t.csdnimg.cn/gbohQ 给定一个链表&#xff0c;判断链表中是否有环。http://t.csdnimg.cn/Rcdyc 给定一个链表&#xff0c;返回链表开始入环的第一个结点。 如果链表无环&#xff0c;则返回 NULLhttp://t.cs…

OpenCV识别人脸案例实战

使用级联函数 基本流程 函数介绍 在OpenCV中&#xff0c;人脸检测使用的是cv2.CascadeClassifier.detectMultiScale()函数&#xff0c;它可以检测出图片中所有的人脸。该函数由分类器对象调用&#xff0c;其语法格式为&#xff1a; objects cv2.CascadeClassifier.detectMul…

vue-进阶语法(四)

目录 v-model原理 v-model应用于组件 sync修饰符 ref 和 $refs&#xff08;重点&#xff09; $nextTick v-model原理 原理&#xff1a;v-model本质上是一个语法糖。例如应用在输入框上&#xff0c;就是 value属性 和 input事件 的合写。 作用&#xff1a;提供数据的双向…

[NSSRound#16 Basic]Web

1.RCE但是没有完全RCE 显示md5强比较&#xff0c;然后md5_3随便传 md5_1M%C9h%FF%0E%E3%5C%20%95r%D4w%7Br%15%87%D3o%A7%B2%1B%DCV%B7J%3D%C0x%3E%7B%95%18%AF%BF%A2%00%A8%28K%F3n%8EKU%B3_Bu%93%D8Igm%A0%D1U%5D%83%60%FB_%07%FE%A2&md5_2M%C9h%FF%0E%E3%5C%20%95r%D4w…