当前位置: 首页 > news >正文

C语言之通讯录的实现篇

目录

test.c

主菜单menu

创建通讯录con

初始化通讯录InitContact

增加个人信息AddContact 

展示个人信息ShowContact

删除个人信息DelContact

查找个人信息SearchContact

修改个人信息ModifyContact

test.c总代码 

contact.h

头文件包含

PeoInfo_个人信息的设置声明

Contact_存放个人信息声明

InitContact_初始化个人信息声明

AddContact_增加个人信息 

ShowContact_展示个人信息

DelContact_删除个人信息

SearchContact_查找个人信息 

ModifyContact_修改个人信息

contact.h总代码 

contact.c

InitContact_初始化个人信息

AddContact_增加个人信息

ShowContact_展示个人信息

DelContact_删除个人信息

FindByName查找函数

SearchContact_查找个人信息

ModifyContact_修改个人信息

contact.c总代码


今天实现同通讯录的功能。在学习了结构体其他的自定义的类型之后,我们就可以实现一个的通讯录。

实现一个通讯录:

  1. 可以保存100个人的信息
  2. 增加人的信息
  3. 删除指定联系人的信息
  4. 查找指定联系人的信息
  5. 修改指定联系人的信息
  6. 显示所有联系人的信息
  7. 排序通讯录的信息
  • 一个人的信息包括:名字+年龄+性别+电话+住址

那接下来我们将从test.c 测试代码  contact.h 声明  contact.c 实现 去实现

test.c

主菜单menu

#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{printf("************************************");printf("********1.add      2.del************");printf("********3.search   4.modify*********");printf("********5.show     6.sort***********");printf("********0.exit           ***********");printf("************************************");
}
enum Option
{EXIT,//0ADD,//1DEL,//2SEARCH,//3MODIFY,//4SHOW,//5SORT,//6	
};
int main()
{int input = 0;Contact con;//创建通讯录condo{menu();printf("请输入你的选择:>\n");scanf("%d", &input);switch (input)//这里为了代码更加清晰用枚举常量{case ADD:break;case DEL:break;case SEARCH:break;case MODIFY:break;case SHOW:break;case SORT:break;case EXIT:printf("退出通讯录\n");break;default:printf("选择错误,请重新选择:>\n");break;}} while (input);return 0;
}
  •  菜单是根据用户需求而设计
  •  使用枚举常量 为了让程序员写代码 更加清晰

创建通讯录con

	Contact con;//创建通讯录con

初始化通讯录InitContact

	InitContact(&con);

这里需要特别注意的是,结构体传参到底是传值还是传地址??🆗忘了小朋友戳一戳

 C语言之结构体篇_唐唐思的博客-CSDN博客

增加个人信息AddContact 

     AddContact(&con);

展示个人信息ShowContact

		ShowContact(&con);//即使这里不需要& 但是出于效率考虑还是需要

删除个人信息DelContact

			DelContact(&con);

查找个人信息SearchContact

			SearchContact(&con);

修改个人信息ModifyContact

			ModifyContact(&con);

test.c总代码 

#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{printf("************************************");printf("********1.add      2.del************");printf("********3.search   4.modify*********");printf("********5.show     6.sort***********");printf("********0.exit           ***********");printf("************************************");
}
enum Option
{EXIT,//0ADD,//1DEL,//2SEARCH,//3MODIFY,//4SHOW,//5SORT,//6	
};
int main()
{int input = 0;//创建通讯录Contact con;//初始化通讯录InitContact(&con);do{menu();printf("请输入你的选择:>\n");scanf("%d", &input);switch (input)//这里为了代码更加清晰用枚举常量{case ADD:AddContact(&con);break;case DEL:DelContact(&con);break;case SEARCH:SearchContact(&con);break;case MODIFY:ModifyContact(&con);break;case SHOW:ShowContact(&con);break;case SORT:break;case EXIT:printf("退出通讯录\n");break;default:printf("选择错误,请重新选择:>\n");break;}} while (input);return 0;
}

contact.h

contact.h文件主要是头文件的包含

头文件包含

在我们写代码的过程中,会调用库函数,需要包含头文件,和声明函数。

所以我们将所有函数声明和头文件放到我们.h 文件中。

当然,在其他.c文件需要使用时,我们只需要包含 我们创造的 头文件"contact.h" 即可

  • 自己创建的头文件用" " 双引号,库函数的头文件用< >
#pragma once
#include<stdio.h>
#include<string.h>
#include<assert.h>

              

PeoInfo_个人信息的设置声明

我们怎样去设置一个人的全部信息呢?姓名+年龄+性别+电话+住址 都是需要不同类型的变量去设置,所以我们把它们都放到【结构体】里面。

#define NAME_MAX 20
#define SEX_MAX 20
#define TELE_MAX 20
#define ADDR_MAX 20typedef struct PeoInfo
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tele[TELE_MAX];char addr[ADDR_MAX];
}PeoInfo;
  • typedef是定义结构体类型由struct PeoInfo---> PeoInfo (这样后面使用定义变量时类型就直接写PeoInfo就可以了)
  • 数组【】里面如果是常量 那就后期想修改是非常不方便的,所以我们自己定义NAME_MAX等,后期修改起来更加方便。

Contact_存放个人信息声明

如果我想存放100个人的信息,那我们怎样去存放100个人的信息呢?用结构体数组(所谓就是存放结构体类型变量的数组)

#define MAX 100
typedef struct Contact
{PeoInfo data[MAX];//存放数据int sz;//记录当前通讯录中存放的人的信息个数
}Contact;//通讯录
  • typedef是定义结构体类型由struct Contact---> Contact (这样后面使用定义变量时类型就直接写Contact就可以了)
  • 数组【】里面如果是常量 那就后期想修改是非常不方便的,所以我们自己定义MAX等,后期修改起来更加方便。
  • 可以通俗理解为:一个结构体类型的数组data里面存放一个一个的结构体数据。一个结构体类型的数据就是PeoInfo

InitContact_初始化个人信息声明

初步创建完成我们的通讯录,那我们调试发现通讯录里面全是随机值,所以我们需要封装一个函数去初始化个人信息。

void InitContact(Contact* pc);

AddContact_增加个人信息 

void AddContact(Contact* pc);

ShowContact_展示个人信息

void ShowContact(Contact* pc);

DelContact_删除个人信息

void DelContact(Contact *pc);

SearchContact_查找个人信息 

void SearchContact(Contact* pc);

ModifyContact_修改个人信息

void ModifyContact(Contact* pc);

contact.h总代码 

#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void InitContact(Contact* pc)
{assert(pc);pc->sz = 0;memset(pc->data, 0, sizeof(pc->data));
}
void AddContact(Contact* pc)
{assert(pc);printf("请输入名字\n");scanf("%s", pc->data[pc->sz].name);//name是数组名,不用&printf("请输入年龄\n");scanf("%s", &(pc->data[pc->sz].age));//printf("请输入性别\n");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话\n");scanf("%s", pc->data[pc->sz].tele);printf("请输入地址\n");scanf("%s", pc->data[pc->sz].addr);//pc->sz++;printf("增加成功\n");
}void ShowContact(const Contact* pc)
{assert(pc);if (pc->sz == 0){printf("通讯录为空,无需打印\n");return 0;}int i = 0;//名字 年龄 性别 电话 地址//-左对齐//20是需要20字符的位置来放名字 printf("%-20s%-5s%-5s%-12s%-30s\n", "姓名", "年龄", "性别", "电话", "地址");for (i = 0; i < pc->sz; i++){printf("%-20s%-5d%-5s%-12s%-30s\n",pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);}
}void DelContact(Contact* pc)//删除
{char name[NAME_MAX];//assert(pc);if (pc->sz == 0){printf("通讯录为空,无法删除\n");return;}printf("输入要删除的名字:>");scanf("%s", name);int ret = FindByName(pc, name);if (ret == -1){printf("要删除的人不存在\n");return;}//存在返回这个人的所在data的下标放入retint i = 0;for (i = ret; i < pc -> sz - 1; i++){pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功\n");
}int FindByName(Contact* pc, char name[])
{assert(pc);int i = 0;for (i = 0; i < pc->sz; i++){if (strcmp(pc->data[i].name, name) == 0){return i;}}return -1;
}void SearchContact(Contact* pc)
{char name[NAME_MAX];assert(pc);//查找printf("输入要查找的名字:>");scanf("%s", name);int ret = FindByName(pc, name);if (ret == -1){printf("要查找的人不存在\n");return;}//显示printf("%-20s%-5s%-5s%-12s%-30s\n", "姓名", "年龄", "性别", "电话", "地址");int i = 0;for (i = 0; i < pc->sz; i++){printf("%-20s%-5d%-5s%-12s%-30s\n",pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);}
}void ModifyContact(Contact* pc)
{char name[NAME_MAX];assert(pc);//查找printf("输入要修改的名字:>");scanf("%s", name);int ret = FindByName(pc, name);if (ret == -1){printf("要修改的人不存在\n");return;}//修改assert(pc);printf("请输入名字\n");scanf("%s", pc->data[pc->sz].name);//name是数组名,不用&printf("请输入年龄\n");scanf("%s", &(pc->data[pc->sz].age));//printf("请输入性别\n");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话\n");scanf("%s", pc->data[pc->sz].tele);printf("请输入地址\n");scanf("%s", pc->data[pc->sz].addr);//printf("修改成功\n");
}

contact.c

InitContact_初始化个人信息

void InitContact(Contact* pc)
{assert(pc);pc->sz = 0;memset(pc->data, 0, sizeof(pc->data));
}
  • 传地址的结构体访问两种方式:->    *( ). 
  • 关于memset内存函数的复习,戳一戳:C语言之内存函数篇(3)_唐唐思的博客-CSDN博客
  •  data是数组名 访问数组名即访问数组的第一个元素,单独放在sizeof里面,整个数组的大小
  •  不要遗忘assert去断言,这里要修改pc指向的空间修改,所以不需要const修饰。

完成了我们的通讯录的初始化,感觉要长脑子了。 接下来一步一步实现它的功能。

AddContact_增加个人信息

首先,这幅图想说明: data的下标和sz的数值是对应的

void AddContact(Contact* pc)
{assert(pc);printf("请输入名字\n");scanf("%s", pc->data[pc->sz].name);//name是数组名,不用&printf("请输入年龄\n");scanf("%d", &(pc->data[pc->sz].age));//printf("请输入性别\n");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话\n");scanf("%s", pc->data[pc->sz].tele);printf("请输入地址\n");scanf("%s", pc->data[pc->sz].addr);//pc->sz++;printf("增加成功\n");
}
  • scanf输入 %d %s
  • scanf输入& 
  • 结构体访问成员

ShowContact_展示个人信息

我们改动了通讯录之后,我们都需要去观察一下通讯录,这个时候需要封装函数去实现这个功能 

void ShowContact(const Contact* pc)
{assert(pc);if (pc->sz == 0){printf("通讯录为空,无需打印\n");return 0;}int i = 0;//名字 年龄 性别 电话 地址//-左对齐//20是需要20字符的位置来放名字 printf("%-20s%-5s%-5s%-12s%-30s\n", "姓名", "年龄", "性别", "电话", "地址");for (i = 0; i < pc->sz; i++){printf("%-20s%-5d%-5s%-12s%-30s\n",pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);}
  • const 和 assert
  • 结构体的访问
  •  一定要判断一下通讯录里的是否有数据
  • 格式美观:%-20s  是左对齐20个字符的空间大小
  • %s %d

DelContact_删除个人信息

删除联系人,我们首先需要找到联系人,我们就去封装一个查找的函数【FindByname】:把通讯录遍历一遍,找到了就返回下标,找不到就返回-1。其实我们发现后面 查找 修改 删除的功能都需要用这个函数。

void DelContact(Contact* pc)//删除
{char name[NAME_MAX];//assert(pc);if (pc->sz == 0){printf("通讯录为空,无法删除\n");return;}printf("输入要删除的名字:>");scanf("%s", name);int ret = FindByName(pc, name);if (ret == -1){printf("要删除的人不存在\n");return;}//存在返回这个人的所在data的下标放入retint i = 0;for (i = ret; i < pc -> sz - 1; i++){pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功\n");
}

FindByName查找函数

static int FindByName(Contact* pc, char name[])
{assert(pc);int i = 0;for (i = 0; i < pc->sz; i++){if (strcmp(pc->data[i].name, name) == 0){return i;}}return -1;
}

SearchContact_查找个人信息

void SearchContact(Contact* pc)
{char name[NAME_MAX];assert(pc);//查找printf("输入要查找的名字:>");scanf("%s", name);int ret = FindByName(pc, name);if (ret == -1){printf("要查找的人不存在\n");return;}//显示printf("%-20s%-5s%-5s%-12s%-30s\n", "姓名", "年龄", "性别", "电话", "地址");int i = 0;for (i = 0; i < pc->sz; i++){printf("%-20s%-5d%-5s%-12s%-30s\n",pc->data[i].name, pc->data[i].age, pc->data[i].sex, pc->data[i].tele, pc->data[i].addr);}
}

ModifyContact_修改个人信息

void ModifyContact(Contact* pc)
{char name[NAME_MAX];assert(pc);//查找printf("输入要修改的名字:>");scanf("%s", name);int ret = FindByName(pc, name);if (ret == -1){printf("要修改的人不存在\n");return;}//修改assert(pc);printf("请输入名字\n");scanf("%s", pc->data[pc->sz].name);//name是数组名,不用&printf("请输入年龄\n");scanf("%s", &(pc->data[pc->sz].age));//printf("请输入性别\n");scanf("%s", pc->data[pc->sz].sex);printf("请输入电话\n");scanf("%s", pc->data[pc->sz].tele);printf("请输入地址\n");scanf("%s", pc->data[pc->sz].addr);//printf("修改成功\n");
}

contact.c总代码

#pragma once
#include<stdio.h>
#include<string.h>
#include<assert.h>#define NAME_MAX 20
#define SEX_MAX 20
#define TELE_MAX 20
#define ADDR_MAX 30
#define MAX 100
typedef struct PeoInfo
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tele[TELE_MAX];char addr[ADDR_MAX];
}PeoInfo;typedef struct Contact
{PeoInfo data[MAX];//存放数据int sz;//记录当前通讯录中存放的人的信息个数
}Contact;//初始化通讯录
void InitContact(Contact* pc);//增加个人信息
void AddContact(Contact* pc);//展示个人信息
void ShowContact(Contact* pc);//删除个人信息
void DelContact(Contact *pc);//查找个人信息
void SearchContact(Contact* pc);//修改个人信息
void ModifyContact(Contact* pc);

✔✔✔✔✔最后,感谢大家的阅读,若有错误和不足,欢迎指正!

希望大家都有好好学习,好好敲代码。好好生活哦

代码------→【gitee:唐棣棣 (TSQXG) - Gitee.com】

联系------→【邮箱:2784139418@qq.com】

相关文章:

C语言之通讯录的实现篇

目录 test.c 主菜单menu 创建通讯录con 初始化通讯录InitContact 增加个人信息AddContact 展示个人信息ShowContact 删除个人信息DelContact 查找个人信息SearchContact 修改个人信息ModifyContact test.c总代码 contact.h 头文件包含 PeoInfo_个人信息的设置声…...

如何降低海康、大华等网络摄像头调用的高延迟问题(二)

目录 1.RTSP介绍 2.解决办法1 3.解决办法2 1.RTSP介绍 RTSP&#xff08;Real-time Streaming Protocol&#xff09;是一种用于实时流媒体传输的网络协议。它被设计用于在服务器和客户端之间传输音频、视频以及其他流媒体数据。 RTSP协议允许客户端通过与服务器建立RTSP会话…...

centos清理日志和缓存

今天使用redmine修改密码&#xff0c;修改报错&#xff0c;再去试试创建用户&#xff0c;创建用户的页面直接报错显示不出来。然后看了一下服务器&#xff0c;发现服务器磁盘空间全部占满了。 CentOS系统也会在使用很长一段时间后出现硬盘空间开始不够的情况&#xff0c;而这并…...

排序算法的稳定性

什么是排序算法的稳定性&#xff1f; 排序算法的稳定性&#xff1a; 假定在待排序的记录序列中&#xff0c;存在多个具有相同的关键字的记录&#xff0c;若经过排序&#xff0c;这些记录的相对次序保持不变&#xff0c;即在原序列中&#xff0c;r[i] r[j]&#xff0c;且 r[i…...

kafka属性说明

kafka中关于一些字段说明 groupId :标识消费者分组id&#xff0c;如果多个消费者id相同&#xff0c;就表示这几个消费者是一组&#xff0c;当一组多个消费者消费同一个topic时&#xff0c;一组中只会有一个成功消费 代码如下 这时只会有一条消息被消费...

STM32F4使用ucosii时操作浮点数卡死的问题

STM32F4使用ucosii时操作浮点数卡死的问题_stm32 fpu float 程序跑不起来_shou撕代码的博客-CSDN博客...

python练习:赋值运算 => 输入身高,体重,求BMI = 体重(kg)/身高(m)的平方。

赋值运算 > 输入身高&#xff0c;体重&#xff0c;求BMI 体重(kg)/身高(m)的平方。 代码&#xff1a; height float(input(‘请输入您的身高&#xff08;m&#xff09;&#xff1a;’)) weight float(input(‘请输入您的体重&#xff08;kg&#xff09;&#xff1a;’))…...

PCL ICP精配准(点到点)

文章目录 一、简介二、实现过程三、实现效果参考资料一、简介 迭代最近点(ICP)算法作为是目前最常用的刚性点集配准方法,它有着简单、计算复杂度低等优点,该算法的具体计算过程如下: (1)在目标点云P中取点集 p i ∈ P p_i∈P p...

Redis数据缓存(Redis的缓存击穿和穿透的区别)

Redis是一个高性能的内存中数据存储系统&#xff0c;可以使用它作为数据缓存。使用Redis作为数据缓存可以提高应用程序的性能和可伸缩性&#xff0c;因为Redis运行在内存中&#xff0c;读写速度非常快。 Redis支持许多数据结构&#xff0c;如字符串、哈希表、列表、集合和有序…...

八大排序算法(含时间复杂度、空间复杂度、算法稳定性)

文章目录 八大排序算法(含时间复杂度、空间复杂度、算法稳定性)1、&#xff08;直接&#xff09;插入排序1.1、算法思想1.2、排序过程图解1.3、排序代码 2、希尔排序3、冒泡排序3.1、算法思想3.2、排序过程图解3.3、排序代码 4、&#xff08;简单&#xff09;选择排序4.1、算法…...

【C++】:引用的概念/引用的特性/常引用/引用的使用场景/传值与传引用的效率比较/引用和指针的区别/内联函数的概念/内联函数的特性

引用的概念 引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0c;编译器不会为引用变量开辟内存空间&#xff0c;它和它引用的变量共用同一块内存空间 比如&#xff1a;李逵&#xff0c;在家称为"铁牛"&#xff0c;江湖上人称"黑旋风&…...

Python点云处理(十七)点云地面点提取——基于格网算法

目录 0 简述1 算法流程2 优缺点3 实现4 效果5 结语0 简述 提取地面点是点云数据分析和处理中的重要任务,而点云格网法是一种常用的地面点提取方法。点云格网法(Grid-based Method),通过将点云数据划分为网格单元,根据高程值分析来实现地面点的提取。 1 算法流程 步骤1:…...

Flink 中kafka broker缩容导致Task一直重启

背景 Flink版本 1.12.2 Kafka 客户端 2.4.1 在公司的Flink平台运行了一个读Kafka计算DAU的流程序&#xff0c;由于公司Kafka的缩容&#xff0c;直接导致了该程序一直在重启&#xff0c;重启了一个小时都还没恢复&#xff08;具体的所容操作是下掉了四台kafka broker&#xff0…...

纯前端js中使用sheetjs导出excel,并且合并标题

先定义变量----用的是Vue2 &#xff0c;以下在vue的data&#xff1a;{}中定义--------------//空格占位符 headerTopTitle: [患者信息, , , , , , , , , 入出院信息, , , , , , , 病案首页中的出院主要诊断, ,出院其他诊断&#xff08;病案首页中原始信息&#xff09;, , , , ,…...

猫眼 校园招聘_1面

&#xff08;1&#xff09;打包和构建工具 vite 和 webpack 功能 1. 构建原理&#xff1a; Webpack 是一个静态模块打包器&#xff0c;通过对项目中的JavaScript、css、Image 等文件进行分析&#xff0c;生成对应的静态资源&#xff0c;并且通过一些插件和加载器来实现各种功…...

博弈论——博弈信息结构

博弈信息结构 0 引言 在一个博弈构成中&#xff0c;博弈信息结构是不可或缺要素。博弈信息&#xff0c;顾名思义&#xff0c;就是在博弈中&#xff0c;博弈方对于信息的了解。知己知彼&#xff0c;百战不殆。和短兵相接的战争一样&#xff0c;只有充分了解自己的优劣势&#x…...

求二叉树的高度——函数递归的思想

二叉树的高度&#xff1a;左右两个数最高的那个的1 int TreeHight(BTNode* root) {if (root NULL){return 0;}int lefhightTreeHight(root->left);int righthight TreeHight(root->right);return lefhight > righthight ? TreeHight(root->left) 1 : TreeHight…...

ue5蓝图请求接口

安装与使用 1、在虚幻商城搜索 VaRest 插件 2、选择自己项目的对应版本安装 3、查看是否安装成功 4、进入项目后&#xff0c;分别启动VaRest、JSON Blueprint Utilities两个插件&#xff08;勾选后会提示重启项目&#xff09; 5、基本用法&#xff1a;打开关卡蓝图使用&#xf…...

windows server 2012 查看已打了哪些补丁

打开控制面板 点击卸载程序 点击 查看已安装的更新 下图是已安装的补丁...

参加CSP-J第一轮后的感受

本人现在初二。作为一名学了4年多c的人&#xff0c;我一直都挺想考过CSP。于是&#xff0c;去年我就去考了。 当时初一&#xff0c;感觉自己实力不够&#xff0c;就只报了J组的。果不其然&#xff0c;63分&#xff0c;没过。 经过1年的苦练&#xff0c;今年又去考了。 J组78分&…...

使用VSCode开发Django指南

使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架&#xff0c;专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用&#xff0c;其中包含三个使用通用基本模板的页面。在此…...

SCAU期末笔记 - 数据分析与数据挖掘题库解析

这门怎么题库答案不全啊日 来简单学一下子来 一、选择题&#xff08;可多选&#xff09; 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘&#xff1a;专注于发现数据中…...

微信小程序云开发平台MySQL的连接方式

注&#xff1a;微信小程序云开发平台指的是腾讯云开发 先给结论&#xff1a;微信小程序云开发平台的MySQL&#xff0c;无法通过获取数据库连接信息的方式进行连接&#xff0c;连接只能通过云开发的SDK连接&#xff0c;具体要参考官方文档&#xff1a; 为什么&#xff1f; 因为…...

Java多线程实现之Thread类深度解析

Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...

Pinocchio 库详解及其在足式机器人上的应用

Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库&#xff0c;专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性&#xff0c;并提供了一个通用的框架&…...

算法岗面试经验分享-大模型篇

文章目录 A 基础语言模型A.1 TransformerA.2 Bert B 大语言模型结构B.1 GPTB.2 LLamaB.3 ChatGLMB.4 Qwen C 大语言模型微调C.1 Fine-tuningC.2 Adapter-tuningC.3 Prefix-tuningC.4 P-tuningC.5 LoRA A 基础语言模型 A.1 Transformer &#xff08;1&#xff09;资源 论文&a…...

C++.OpenGL (14/64)多光源(Multiple Lights)

多光源(Multiple Lights) 多光源渲染技术概览 #mermaid-svg-3L5e5gGn76TNh7Lq {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-3L5e5gGn76TNh7Lq .error-icon{fill:#552222;}#mermaid-svg-3L5e5gGn76TNh7Lq .erro…...

【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题

【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要&#xff1a; 近期&#xff0c;在使用较新版本的OpenSSH客户端连接老旧SSH服务器时&#xff0c;会遇到 "no matching key exchange method found"​, "n…...

【无标题】路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论

路径问题的革命性重构&#xff1a;基于二维拓扑收缩色动力学模型的零点隧穿理论 一、传统路径模型的根本缺陷 在经典正方形路径问题中&#xff08;图1&#xff09;&#xff1a; mermaid graph LR A((A)) --- B((B)) B --- C((C)) C --- D((D)) D --- A A -.- C[无直接路径] B -…...

虚拟电厂发展三大趋势:市场化、技术主导、车网互联

市场化&#xff1a;从政策驱动到多元盈利 政策全面赋能 2025年4月&#xff0c;国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》&#xff0c;首次明确虚拟电厂为“独立市场主体”&#xff0c;提出硬性目标&#xff1a;2027年全国调节能力≥2000万千瓦&#xff0…...