指针(5)加油吧

news2024/11/15 12:05:19

指针(5)

拿冒泡排序来举例:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1 .qsort

void qsort (
	void* base,//base指向待排序数组的首元素的指针
	size_t num,//base指向数组中元素的个数
	size_t size,//base指向的数组中的一个元素的大小,单位是字节
	int(*cmp)(const void*,const void*)//函数指针,传递函数的地址
	);


外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

qsort的头文件是==<stdlib.h>==

测试qsort,来排序整型数据

void print_arr(int arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
}

int cmp_int(const void* p1, const void* p2)
{
	if (*(int*)p1 > *(int*)p2)
	return 1;
	else if (*(int*)p1 < *(int*)p2)
		return -1;
	else
		return 0;//可以简化为return *(int*)p1-*(int*)p2
}
void test1()
{
	int arr[] = { 3,1,4,2,6,5,7,8,9,10 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), cmp_int);
	print_arr(arr, sz);
}
int main() {
	test1();
	return 0;
}

补充个小知识:

怎样访问结构体的内容

struct Stu{
    char name [20];
    int age;
}
int main()
{
    struct Stu s{"maya",20};
    printf("%s %d\n",s.name,s.age);
    struct Stu *ps=&s;
    printf("%s %d\n",(*ps).name,(*ps).age);
    printf("%s &d\n",ps->name,ps->age);
    return 0;
}

结构体成员访问操作符:

. 结构体变量.成员名

-> 结构体指针->成员名

测试qsort函数排序结构体数据

struct Stu
{
	char name[20];
	int age;
};//名字是字符串,字符串比较是用strcmp函数的
int  cmp_stu_by_name(const void* p1, const void* p2)
{
	return strcmp(((struct Stu*)p1)->name, ((struct Stu*)p2)->name);

}
void test2()
{
	struct Stu arr[] = { {"zhangsan",28},{"lisi",40},{"wangwu",12} };
	int len = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, len, sizeof(arr[0]), cmp_stu_by_name);
}
int  cmp_stu_by_age(const void* p1, const void* p2)
{
	return strcmp(((struct Stu*)p1)->age, ((struct Stu*)p2)->age);

}
void test3()
{
	struct Stu arr[] = { {"zhangsan",28},{"lisi",40},{"wangwu",12} };
	int len = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, len, sizeof(arr[0]), cmp_stu_by_age);
}
int main() {
	test2();
	test3();
	return 0;
}

补充知识:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

注意点:

qsort默认的顺序是升序排列

怎样实现降序呢

可以调换p1和p2顺序

2 .改造冒泡排序

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

swap交换两个元素

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

详细逻辑分析图:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

注意点:为什么强制类型转换的是char呢,我们知道qsort函数base指向的数组中的一个元素的大小,单位是字节,如果换成int,一次跳过四个字节,力度太大了

这也是一个泛型编程,就是不管什么类型的都能处理

3 .sizeof和strlen对比

sizeof是操作符,不是函数

strlen是函数,求字符串长度,只针对字符串(字符数组),统计的是字符串中==\0==前的个数

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

int main()
{
	int arr[] = { 1,2,3,4,5,0};
	//01 00 00 00 02 00 00 00 03 00 00 00 ...
    //00相当于\0,strlen遇到\0就停止计算
	printf("%zd\n", strlen(arr));

	return 0;
}

sizeof和strlen对比总结

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

4 .数组和指针笔试题解析

4 .1一维数组

前情回顾:

数组名是数组首元素的地址

两个例外:

sizeof(数组名)

&(数组名)

int a[] = {1,2,3,4};
printf("%zd\n",sizeof(a));//16
//数组名a单独放在sizeof内部,a表示整个数组,计算的是整个数组的大小,单位是字节
printf("%zd\n",sizeof(a+0));//这里的a是数组名表示首元素的地址,a+0还是首元素的地址
//这里sizeof计算的是首元素地址的大小 4/8
printf("%zd\n",sizeof(*a));//4 这里的a是数组名表示首元素的地址,*a 就是首元素,就是a[0]
//*a -- *(a+0) -- a[0]
printf("%zd\n",sizeof(a+1));//这里的a是数组名表示首元素的地址,a+1是第二个元素的地址(&a[1])
//计算的是地址的大小 4/8
printf("%zd\n",sizeof(a[1]));//4
printf("%zd\n",sizeof(&a));//&a - 这里的数组名a表示整个数组,&a是整个数组的地址
//数组的地址也是地址,是地址就是 4/8 个字节的长度",sizeof(&a));
printf("%zd\n",sizeof(*&a));
//1. *&a,这里的*和&抵消了,所以sizeof(*&a) == sizeof(a) 16
//2. &a - 这是数组的地址,类型是:int(*)[4],*&a 访问的就是这个数组
printf("%zd\n",sizeof(&a+1));
//&a是数组的地址,&a+1是跳过整个数组后的那个位置的地址
//&a+1是地址,地址都是4/8个字节
printf("%zd\n",sizeof(&a[0]));//4/8
printf("%zd\n",sizeof(&a[0]+1));//第二个元素的地址 4/8

再来一组(字符数组):

int main()
{
	char arr[] = { 'a','b','c','d','e','f' };

	printf("%d\n", sizeof(arr));//6
	printf("%d\n", sizeof(arr + 0));//4/8
	printf("%d\n", sizeof(*arr));//1
	printf("%d\n", sizeof(arr[1]));//1
	printf("%d\n", sizeof(&arr));//4/8
	printf("%d\n", sizeof(&arr + 1));//4/8
	printf("%d\n", sizeof(&arr[0] + 1));//4/8

	return 0;
}

strlen

#include <string.h>

int main()
{
	char arr[] = { 'a','b','c','d','e','f' };
	printf("%zd\n", strlen(arr));//随机值
	printf("%zd\n", strlen(arr + 0));//随机值
	//printf("%zd\n", strlen(*arr));//arr是数组名表示首元素的地址
	//*arr 是首元素 -- 'a' - 97 ,传递给strlen后,strlen 会认为97就是地址,然后去访问内存
	//err -- 程序崩溃
	//printf("%zd\n", strlen(arr[1]));//'b' -98 //err
	printf("%zd\n", strlen(&arr));//随机值
	printf("%zd\n", strlen(&arr + 1));//随机值
	printf("%zd\n", strlen(&arr[0] + 1));//随机值

	return 0;
}
  • 97 ,传递给strlen后,strlen 会认为97就是地址,然后去访问内存
    //err – 程序崩溃
    //printf(“%zd\n”, strlen(arr[1]));//‘b’ -98 //err
    printf(“%zd\n”, strlen(&arr));//随机值
    printf(“%zd\n”, strlen(&arr + 1));//随机值
    printf(“%zd\n”, strlen(&arr[0] + 1));//随机值

    return 0;
    }


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端工程化,前端监控,工作流,部署,性能

开发规范 创建项目的时候&#xff0c;配置下 ESlint&#xff0c;stylelint&#xff0c; prettier&#xff0c; commitlint 等; ESLint 主要功能&#xff1a; ESLint 是一个静态代码检查工具&#xff0c;用于在 JavaScript 代码中识别和报告模式。它的目标是提供一个插件化的 …

LeetCode 138. 随机链表的复制

目录 1.原题链接&#xff1a; 2.结点拆分&#xff1a; 代码实现&#xff1a; 3.提交结果&#xff1a; 4.读书分享&#xff1a; 1.原题链接&#xff1a; 138. 随机链表的复制 2.结点拆分&#xff1a; ①.拷贝各个结点&#xff0c;连接在原结点后面&#xff1b; ②.处…

Imitation Learning学习记录(理论例程)

前言 最近还是衔接着之前的学习记录&#xff0c;这次打算开始学习模仿学习的相关原理&#xff0c;参考的开源资料为 TeaPearce/Counter-Strike_Behavioural_Cloning: IEEE CoG & NeurIPS workshop paper ‘Counter-Strike Deathmatch with Large-Scale Behavioural Clonin…

【源头开发】运营级竞拍商城源码/抢拍转拍/竞拍源码/转卖寄售/拆分/溢价商城转拍溢价php源码uniapp源码

大家好啊&#xff0c;欢迎来到web测评&#xff0c;我是年哥&#xff0c;我们有个小伙伴又开发了一款竞拍商城的源码&#xff0c;是此系统的源头开发者&#xff0c;本系统是前后端分离的架构&#xff0c;前端php&#xff0c;后端uniapp&#xff0c;系统现在是持续的在更新中&…

libcity笔记: HSTLSTMEncoder

1 __init__ 2 encode 得到的内容如下&#xff1a; data_feature的内容&#xff1a; 一共有多少个location1【包括pad的一个】最长的时间间隔&#xff08;秒&#xff09;最长的距离间隔&#xff08;千米&#xff09;多少个useer idpadding 的locationidpad_item的内容 location…

[单机]成吉思汗3_GM工具_VM虚拟机

稀有端游成吉思汗1,2,3单机版虚拟机一键端完整版 本教程仅限学习使用&#xff0c;禁止商用&#xff0c;一切后果与本人无关&#xff0c;此声明具有法律效应&#xff01;&#xff01;&#xff01;&#xff01; 教程是本人亲自搭建成功的&#xff0c;绝对是完整可运行的&#x…

React 第三十一章 前端框架的分类

现代前端框架&#xff0c;有一个非常重要的特点&#xff0c;那就是基于状态的声明式渲染。如果要概括的话&#xff0c;可以使用一个公式&#xff1a; UI f&#xff08;state&#xff09; state&#xff1a;当前视图的一个状态f&#xff1a;框架内部的一个运行机制UI&#xff1…

计算机视觉——基于改进UNet图像增强算法实现

1. 引言 在低光照条件下进行成像非常具有挑战性&#xff0c;因为光子计数低且存在噪声。高ISO可以用来增加亮度&#xff0c;但它也会放大噪声。后处理&#xff0c;如缩放或直方图拉伸可以应用&#xff0c;但这并不能解决由于光子计数低导致的低信噪比&#xff08;SNR&#xff…

从头理解transformer,注意力机制(下)

交叉注意力 交叉注意力里面q和KV生成的数据不一样 自注意力机制就是闷头自学 解码器里面的每一层都会拿着编码器结果进行参考&#xff0c;然后比较相互之间的差异。每做一次注意力计算都需要校准一次 编码器和解码器是可以并行进行训练的 训练过程 好久不见输入到编码器&…

【图论 回溯 广度优先搜索】126. 单词接龙 II

本文涉及知识点 图论 回溯 深度优先搜索 广度优先搜索 图论知识汇总 LeetCode 126. 单词接龙 II 按字典 wordList 完成从单词 beginWord 到单词 endWord 转化&#xff0c;一个表示此过程的 转换序列 是形式上像 beginWord -> s1 -> s2 -> … -> sk 这样的单词序…

机器学习入门到放弃2:朴素贝叶斯

1. 算法介绍 1.1 算法定义 朴素贝叶斯分类&#xff08;NBC&#xff09;是以贝叶斯定理为基础并且假设特征条件之间相互独立的方法&#xff0c;先通过已给定的训练集&#xff0c;以特征词之间独立作为前提假设&#xff0c;学习从输入到输出的联合概率分布&#xff0c;再基于学习…

oracle 数据库与服务、实例与SID、表空间、用户与表模式

一、数据库与数据库服务: 概念:就是一个数据库的标识,在安装时就要想好,以后一般不修改,修改起来也麻烦,因为数据库一旦安装,数据库名就写进了控制文件,数据库表,很多地方都会用到这个数据库名。是数据库系统的入口,它会内置一些高级权限的用户如SYS,SYSTEM等。我们…

Xilinx 千兆以太网TEMAC IP核 MDIO 配置及物理接口

基于AXI4-Lite接口可以访问MDIO(Management Data Input/Output)接口&#xff0c;而MDIO接口连接MAC外部的PHY芯片&#xff0c;用户可通过AXI4-Lite接口实现对PHY芯片的配置。 1 MDIO接口简介 开放系统互连模型OSI的最低两层分别是数据链路层和物理层&#xff0c;数据链路层的…

探讨欧盟就人工智能监管达成协议

《人工智能法案》是一项具有里程碑意义的立法&#xff0c;它可以创造一个有利的环境&#xff0c;在这种环境中&#xff0c;人工智能的使用将成为一种更优秀的安全和信任的工具&#xff0c;确保整个欧盟的公共和私人机构利益相关者的参与。 历时3天的“马拉松式”谈判圆满结束&…

数据可视化训练第四天(模拟投掷筛子并且统计频次)

投掷一个筛子 import matplotlib.pyplot as plt from random import randint import numpy as npclass Die:"""模拟投掷筛子"""def __init__(self,num_sides6):self.num_sidesnum_sidesdef roll(self):return randint(1,self.num_sides)num1000…

vi\vim编辑器

root用户&#xff08;超级管理员&#xff09; 无论是Windows、MacOS、Linux均采用多用户的管理模式进行权限管理。 在Linux系统中&#xff0c;拥有最大权限的账户名为&#xff1a;root&#xff08;超级管理员&#xff09; root用户拥有最大的系统操作权限&#xff0c;而普通…

论文盲审吐槽多,谁给盲审不负责的老师买单?如何看待浙江大学「一刀切」的研究生学位论文双盲评审制度?

::: block-1 “时问桫椤”是一个致力于为本科生到研究生教育阶段提供帮助的不太正式的公众号。我们旨在在大家感到困惑、痛苦或面临困难时伸出援手。通过总结广大研究生的经验&#xff0c;帮助大家尽早适应研究生生活&#xff0c;尽快了解科研的本质。祝一切顺利&#xff01;—…

二维数组 和 变长数组

在上一期的内容中&#xff0c;为诸君讲解到了一维数组&#xff0c;在一维数组的基础上&#xff0c;C语言中还有着多维数组&#xff0c;其中&#xff0c;比较典型且运用较为广泛的就是我们今天的主角——二维数组 一 . 二维数组的概念 我们把单个或者多个元素组成的数组定义为一…

DI-engine强化学习入门(七)如何自定义神经网络模型

在强化学习中,需要根据决策问题和策略选择合适的神经网络。DI-engine中,神经网络模型可以通过两种方式指定: 使用配置文件中的cfg.policy.model自动生成默认模型。这种方式下,可以在配置文件中指定神经网络的类型(MLP、CNN等)以及超参数(隐层大小、激活函数等),DI-engine会根据…

【漏洞复现】泛微OA E-Cology XmlRpcServlet文件读取漏洞

漏洞描述&#xff1a; 泛微OA E-Cology是一款面向中大型组织的数字化办公产品&#xff0c;它基于全新的设计理念和管理思想&#xff0c;旨在为中大型组织创建一个全新的高效协同办公环境。泛微OA E-Cology XmlRpcServlet存在任意文件读取漏洞&#xff0c;允许未经授权的用户读…