通讯录项目(用c语言实现)

一.什么是通讯录

通讯录是一种用于存储联系人信息的工具或应用程序。它是一种电子化的地址簿,用于记录和管理个人、机构或组织的联系方式,如姓名、电话号码、电子邮件地址和邮寄地址等。通讯录的目的是方便用户在需要时查找和联系他人。

通讯录通常以列表或表格的形式呈现,每个条目代表一个联系人。用户可以根据联系人的姓名、公司、职位或其他标识符来组织和排序通讯录。随着技术的发展,通讯录也可以与其他应用程序、设备或云服务同步,以确保联系人信息的备份和共享。

通讯录在个人生活和商业环境中都非常有用。个人可以使用通讯录存储家庭成员、朋友、同事和其他重要联系人的信息,以便随时与他们保持联系。在商业环境中,通讯录可以用于管理客户、供应商、合作伙伴和员工的联系信息,以便进行业务沟通和合作。

现代的通讯录应用程序通常具有许多高级功能,如快速搜索、批量导入和导出、分组管理、标签和备注、生日提醒、备份和恢复等。这些功能使通讯录更加强大和便捷,满足用户日常联系和管理联系人的需求。

二.通讯录的功能(简易)

1.允许用户添加、编辑和删除联系人信息,包括姓名、电话号码、电子邮件地址、邮寄地址等。

2.快速搜索:提供快速搜索功能,让用户可以根据姓名、公司、职位或其他标识符快速查找特定的联系人。

三.通讯录的函数实现

关于顺序表的补充:

typedef  PeoInfo SLDataType;
typedef struct SeqList
{SLDataType* a;int size;int capacity;
}SL;

用户的信息:

//前置声明
struct SeqList;
typedef struct SeqList contact;
//用户数据
typedef struct PersonInfo
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tel[TEL_MAX];char addr[ADDR_MAX];
}PeoInfo;

实现通讯录项目需要的代码比较多,我们要使用分文件编写。具体内容我就不再赘述了,如果你还有疑问,可以去看我之前发的扫雷项目。

还有要注意的是此项目是基于顺序表封装,如果对顺序表有疑问,请看我的上一篇文章。

1.初始化联系人列表

程序开始时,可以初始化一个空的联系人列表。InitContact(contact* con):初始化通讯录函数。它接受一个指向contact结构体的指针,通过调用SLInit函数初始化通讯录列表,并打印初始化成功的消息。

//初始化通讯录
void SLInit(SL* ps)
{assert(ps);ps->a = (SLDataType*)malloc(INIT_CAPACITY * sizeof(SLDataType));assert(ps->a);ps->size = 0;ps->capacity = INIT_CAPACITY;
}
void InitContact(contact* con)
{SLInit(con);printf("通讯录初始化成功!\n");
}

2.添加联系人

用户可以输入联系人的姓名和电话号码,程序将该联系人添加到列表中。AddContact(contact* con):添加通讯录数据函数。它接受一个指向contact结构体的指针,通过用户输入获取姓名、年龄、性别、电话和地址信息,并调用SLPushBack函数将该联系人信息添加到通讯录列表中,最后打印添加成功的消息。

//添加通讯录数据
void AddContact(contact* con)
{PeoInfo x = { 0 };printf("请输入姓名\n");scanf("%s", x.name);printf("请输入年龄\n");scanf("%d", &x.age);printf("请输入性别\n");scanf("%s", x.sex);printf("请输入电话\n");scanf("%s", x.tel);printf("请输入地址\n");scanf("%s", x.addr);SLPushBack(con, x);printf("添加成功!\n");
}

3.删除联系人

用户可以输入要删除的联系人的姓名,程序将在列表中查找并删除该联系人的信息。DelContact(contact* con):删除通讯录数据函数。它接受一个指向contact结构体的指针,通过将通讯录列表的大小减1来删除最后一个联系人的信息,并打印删除成功的消息。

//删除通讯录数据
void DelContact(contact* con)
{(con->size)--;printf("删除成功!\n");
}

4.显示联系人列表

程序可以显示当前联系人列表中的所有联系人及其电话号码。ShowContact(contact* con):展示通讯录数据函数。它接受一个指向contact结构体的指针,通过遍历通讯录列表,逐个打印联系人的姓名、年龄、性别、电话和地址信息,并打印已全部显示的消息。

/展示通讯录数据
void ShowContact(contact* con) 
{assert(con);printf("姓名 年龄 性别 电话 地址\n");for (int i = 0; i < con->size; i++){printf("%-4s ", ((con->a) + i)->name);printf("%-4d ", ((con->a) + i)->age);printf("%-4s ", ((con->a) + i)->sex);printf("%-4s ", ((con->a) + i)->tel);printf("%-4s ", ((con->a) + i)->addr);printf("\n");}printf("已全部显示!\n");
}

5.查找联系人

用户可以输入要查找的联系人的姓名,程序将在列表中查找并显示该联系人的信息。FindContactname(contact* con):查找通讯录数据函数。它接受一个指向contact结构体的指针,通过用户输入要查找的联系人姓名,然后在通讯录列表中查找匹配的姓名并返回其索引值(下标)。如果找到了匹配的联系人,返回其下标;如果未找到匹配的联系人,返回-1。

//查找通讯录数据
int FindContactname(contact* con) 
{assert(con);printf("请输入联系人的名字\n");char j[NAME_MAX] = { 0 };scanf("%s", j);for (int i = 0; i < (con->size); i++){if (strcmp(((con->a) + i)->name, j) == 0)return i;}return -1;
}

6.修改联系人

用户可以输入要修改的联系人的姓名,程序将在列表中查找并允许用户修改该联系人的信息。ModifyContact(contact* con):修改通讯录数据函数。它接受一个指向contact结构体的指针,首先调用FindContactname函数查找要修改的联系人的下标,如果找到了匹配的联系人,则通过用户输入更新该联系人的姓名、年龄、性别、电话和地址信息。如果未找到匹配的联系人,打印未找到的消息。

//修改通讯录数据
void ModifyContact(contact* con)
{int i = FindContactname(con);if (i >= 0){printf("找到了,下标是%d\n", i);printf("请输入姓名\n");scanf("%s", ((con->a) + i)->name);printf("请输入年龄\n");scanf("%d", &(((con->a) + i)->age));printf("请输入性别\n");scanf("%s", ((con->a) + i)->sex);printf("请输入电话\n");scanf("%s", ((con->a) + i)->tel);printf("请输入地址\n");scanf("%s", ((con->a) + i)->addr);printf("\n");}elseprintf("未找到!\n");
}

7.销毁联系人列表

程序结束时,可以销毁联系人列表,释放内存空间。DestroyContact(contact* con):销毁通讯录数据函数。它接受一个指向contact结构体的指针,通过调用SLDestroy函数销毁通讯录列表,并打印销毁成功的消息。

void SLDestroy(SL* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->size = 0;ps->capacity = 0;
}
//销毁通讯录数据
void DestroyContact(contact* con)
{SLDestroy(con);printf("销毁成功!\n");
}

四.通讯录的菜单实现

main()函数中,首先调用menu()函数打印菜单选项,然后通过动态内存分配创建一个contact结构体的指针p,并调用InitContact()函数初始化通讯录。

接下来,通过一个do-while循环,根据用户输入的选项执行相应的操作。根据用户输入的选项,调用相应的函数,如AddContact()添加联系人、DelContact()删除联系人、FindContactname()查找联系人、ModifyContact()修改联系人和ShowContact()显示通讯录。

循环终止条件是用户输入0,即选择退出通讯录。在循环结束后,调用DestroyContact()函数销毁通讯录,并打印成功退出通讯录的消息。

此程序通过菜单和用户输入实现了对通讯录的基本操作。用户可以根据菜单选项选择要执行的操作,直到选择退出通讯录为止。

#include"contact.h"
#include"SL.h"
void menu()
{printf("*************************\n");printf("1.添加联系人 2.删除联系人\n");printf("3.查找联系人 4.修改联系人\n");printf("5.显示通讯录 0.退出通讯录\n");printf("*************************\n");
}
int main()
{menu();int i = 0;contact* p = (contact*)malloc(sizeof(contact));InitContact(p);do {printf("请输入\n");scanf("%d", &i);switch (i){case 1:{AddContact(p);break;}case 2:{DelContact(p);break;}case 3:{int k = FindContactname(p);if (k >= 0){printf("找到了,下标是%d\n", k);printf("姓名 年龄 性别 电话 地址\n");printf("%-4s ", ((p->a) + k)->name);printf("%-4d ", ((p->a) + k)->age);printf("%-4s ", ((p->a) + k)->sex);printf("%-4s ", ((p->a) + k)->tel);printf("%-4s ", ((p->a) + k)->addr);printf("\n");}elseprintf("未找到!\n");break;}case 4:{ModifyContact(p);break;}case 5:{ShowContact(p);break;}default:{printf("输入错误,请重新输入!\n");break;}}} while (i);DestroyContact(p);printf("已成功退出通讯录\n");return 0;
}

五.通讯录的测试

1.菜单的显示

2.添加联系人

3.删除联系人

4.查找联系人

5.修改联系人

6.显示通讯录

7.删除通讯录

六.通讯录项目的源码

1.顺序表的源码

1.SL.h

SL.h头文件定义了SL数据结构,表示序列列表。它还定义了初始化、销毁、检查容量、推入和弹出列表中的元素、在特定位置插入和删除元素、以及更改给定位置的元素的函数原型。

#pragma once
#define INIT_CAPACITY 4
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include"contact.h"
typedef  PeoInfo SLDataType;
typedef struct SeqList
{SLDataType* a;int size;int capacity;
}SL;
void SLInit(SL* ps);
void SLDestroy(SL* ps);
//void SLPrint(SL* ps);
void SLCheckCapacity(SL* ps);
void SLPushBack(SL* ps, SLDataType x);
void SLPopBack(SL* ps);
void SLPushFront(SL* ps, SLDataType x);
void SLPopFront(SL* ps);
void SLInsert(SL* ps, int pos, SLDataType x);
void SLErase(SL* ps, int pos);
//int SLFind(SL* ps, SLDataType x);
void SLChange(SL* ps, int pos, SLDataType x);

2.Sl.c

Sl.c文件包含了有关顺序表的函数,这些函数实现了一个简单的单链表数据结构,用于管理通讯录数据。通过链表操作函数,可以向链表中添加元素、删除元素、获取元素以及获取链表的大小。这些函数与contact.c文件中的功能函数一起使用,实现了对通讯录数据的管理和操作。

#include"SL.h"
void SLInit(SL* ps)
{assert(ps);ps->a = (SLDataType*)malloc(INIT_CAPACITY * sizeof(SLDataType));assert(ps->a);ps->size = 0;ps->capacity = INIT_CAPACITY;
}
void SLDestroy(SL* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->size = 0;ps->capacity = 0;
}
//void SLPrint(SL* ps)
//{
//	assert(ps);
//	for (int i = 0; i < ps->size; i++)
//	{
//		printf("%d ", *((ps->a) + i));
//	}
//	printf("\n");
//}
void SLCheckCapacity(SL* ps)
{assert(ps);SLDataType* j = NULL;if (ps->size >= ps->capacity){j = realloc(ps->a, 2 * (ps->capacity) * sizeof(SLDataType));if (j){free(ps->a);ps->a = NULL;perror("fault:");}else {ps->a = j;}}assert(ps->a);
}
void SLPushBack(SL* ps, SLDataType x)
{SLCheckCapacity(ps);*((ps->a) + (ps->size)) = x;(ps->size)++;
}
void SLPopBack(SL* ps)
{(ps->size)--;
}
void SLPushFront(SL* ps, SLDataType x)
{assert(ps);SLCheckCapacity(ps);for (int i = (ps->size) - 1; i > 0; i--){*((ps->a) + i) = *((ps->a) + i - 1);}*(ps->a) = x;(ps->size)++;
}
void SLPopFront(SL* ps)
{assert(ps);for (int i = 0; i < ((ps->size) - 1); i++){*((ps->a) + i) = *((ps->a) + i + 1);}(ps->size)--;
}
void SLInsert(SL* ps, int pos, SLDataType x)
{assert(pos <= ps->size + 1);assert(ps);SLCheckCapacity(ps);for (int i = (ps->size) - 1; i > pos; i--){*((ps->a) + i) = *((ps->a) + i - 1);}*(ps->a + pos) = x;(ps->size)++;
}
void SLErase(SL* ps, int pos)
{assert(pos <= ps->size + 1);assert(ps);for (int i = pos; i < ((ps->size) - 1); i--){*((ps->a) + i) = *((ps->a) + i + 1);}(ps->size)--;
}
//int SLFind(SL* ps, SLDataType x)
//{
//	assert(ps);
//	for (int i = 0; i < (ps->size); i++)
//	{
//		if (*((ps->a) + i) == x)
//			return i;
//	}
//	return -1;
//}
void SLChange(SL* ps, int pos, SLDataType x)
{assert(ps);assert(pos <= ps->capacity - 1);*((ps->a) + pos) = x;
}

2.通讯录的源码

1.contact.h

contact.h头文件定义了用于管理联系人列表的数据结构和函数原型。它包括了SL.h头文件,该头文件定义了序列列表的函数和数据结构。

#pragma once
#define _CRT_SECURE_NO_WARNINGS 1
#define NAME_MAX 100
#define SEX_MAX 7
#define TEL_MAX 12
#define ADDR_MAX 100
#include<string.h>
//前置声明
struct SeqList;
typedef struct SeqList contact;
//用户数据
typedef struct PersonInfo
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tel[TEL_MAX];char addr[ADDR_MAX];
}PeoInfo;
//初始化通讯录
void InitContact(contact* con);
//添加通讯录数据
void AddContact(contact* con);
//删除通讯录数据
void DelContact(contact* con);
//展示通讯录数据
void ShowContact(contact* con);
//查找通讯录数据
int FindContactname(contact* con);
//修改通讯录数据
void ModifyContact(contact* con);
//销毁通讯录数据
void DestroyContact(contact* con);

2.contact.c

contact.c文件包含了许多功能函数共同实现了对通讯录数据的初始化、添加、删除、展示、查找、修改和销毁的操作。相应的函数实现了对通讯录数据结构的操作,并通过调用SL.h中的函数实现了具体的链表操作。

#include"contact.h"
#include"SL.h"
//初始化通讯录
void InitContact(contact* con)
{SLInit(con);printf("通讯录初始化成功!\n");
}
//添加通讯录数据
void AddContact(contact* con)
{PeoInfo x = { 0 };printf("请输入姓名\n");scanf("%s", x.name);printf("请输入年龄\n");scanf("%d", &x.age);printf("请输入性别\n");scanf("%s", x.sex);printf("请输入电话\n");scanf("%s", x.tel);printf("请输入地址\n");scanf("%s", x.addr);SLPushBack(con, x);printf("添加成功!\n");
}
//删除通讯录数据
void DelContact(contact* con)
{(con->size)--;printf("删除成功!\n");
}
//展示通讯录数据
void ShowContact(contact* con) 
{assert(con);printf("姓名 年龄 性别 电话 地址\n");for (int i = 0; i < con->size; i++){printf("%-4s ", ((con->a) + i)->name);printf("%-4d ", ((con->a) + i)->age);printf("%-4s ", ((con->a) + i)->sex);printf("%-4s ", ((con->a) + i)->tel);printf("%-4s ", ((con->a) + i)->addr);printf("\n");}printf("已全部显示!\n");
}
//查找通讯录数据
int FindContactname(contact* con) 
{assert(con);printf("请输入联系人的名字\n");char j[NAME_MAX] = { 0 };scanf("%s", j);for (int i = 0; i < (con->size); i++){if (strcmp(((con->a) + i)->name, j) == 0)return i;}return -1;
}
//修改通讯录数据
void ModifyContact(contact* con)
{int i = FindContactname(con);if (i >= 0){printf("找到了,下标是%d\n", i);printf("请输入姓名\n");scanf("%s", ((con->a) + i)->name);printf("请输入年龄\n");scanf("%d", &(((con->a) + i)->age));printf("请输入性别\n");scanf("%s", ((con->a) + i)->sex);printf("请输入电话\n");scanf("%s", ((con->a) + i)->tel);printf("请输入地址\n");scanf("%s", ((con->a) + i)->addr);printf("\n");}elseprintf("未找到!\n");
}
//销毁通讯录数据
void DestroyContact(contact* con)
{SLDestroy(con);printf("销毁成功!\n");
}

3.test.c

代码中的main()函数是程序的入口点。它显示一个菜单选项,用于管理联系人列表,并重复提示用户输入,直到用户选择退出程序。根据用户的输入,它调用相应的函数来执行所需的操作。

#include"contact.h"
#include"SL.h"
void menu()
{printf("*************************\n");printf("1.添加联系人 2.删除联系人\n");printf("3.查找联系人 4.修改联系人\n");printf("5.显示通讯录 0.退出通讯录\n");printf("*************************\n");
}
int main()
{menu();int i = 0;contact* p = (contact*)malloc(sizeof(contact));InitContact(p);do {printf("请输入\n");scanf("%d", &i);switch (i){case 1:{AddContact(p);break;}case 2:{DelContact(p);break;}case 3:{int k = FindContactname(p);if (k >= 0){printf("找到了,下标是%d\n", k);printf("姓名 年龄 性别 电话 地址\n");printf("%-4s ", ((p->a) + k)->name);printf("%-4d ", ((p->a) + k)->age);printf("%-4s ", ((p->a) + k)->sex);printf("%-4s ", ((p->a) + k)->tel);printf("%-4s ", ((p->a) + k)->addr);printf("\n");}elseprintf("未找到!\n");break;}case 4:{ModifyContact(p);break;}case 5:{ShowContact(p);break;}default:{printf("输入错误,请重新输入!\n");break;}}} while (i);DestroyContact(p);printf("已成功退出通讯录\n");return 0;
}

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

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

相关文章

手眼标定问题排查_2_圆网格数据排查

经过昨天晚上的调试&#xff0c;发现了一个主要问题&#xff1a;使用圆网格标定板标定时&#xff0c;不能使用cornerSubPix()函数&#xff0c;否则寻找角点时&#xff0c;会导致图一的情况(裁剪为30万像素)。就找到能参考的程序&#xff0c;推进还是很快的。 图一 一些数据对比…

imu6xl点灯(C语言)

参考正点原子开发指南 根据原理图可以看出&#xff0c;我们需要设置低电平导通电路。 在原理图上找到LED0&#xff0c;对应IO为GPIO3 IO复用配置 IMX6UL每个引脚都可以复用 在用户手册第30章可以找到IOMUXC_SW_MUX_CTL_PAD_GPIO1_IO03这个寄存器&#xff0c;地址为0x020E0068&…

Linux网络名称空间和虚拟机有何区别

在Linux系统中&#xff0c;网络名称空间和虚拟机都是实现资源隔离和虚拟化的技术&#xff0c;但它们在设计理念、实现机制、资源消耗、使用场景等方面存在着显著的区别。本文旨在全方位、系统性地分析这两种技术的区别。&#x1f50d; 1. 设计理念与实现机制 1.1. 网络名称空…

未来汽车硬件安全的需求(2)

目录 4.汽车安全控制器 4.1 TPM2.0 4.2 安全控制器的硬件保护措施 5. EVITA HSM和安全控制器结合 6.小结 4.汽车安全控制器 汽车安全控制器是用于汽车工业安全关键应用的微控制器。 他们的保护水平远远高于EVITA HSM。今天的典型应用是移动通信&#xff0c;V2X、SOTA、…

python使用ffmpeg分割视频为Hls分片文件/使用OpenSSL加密m3u8和TS文件

FFmpeg和OpenSSL是一个开源免费的软件&#xff0c;在官网上就能下载&#xff0c; FFmpage网址&#xff08;建议选择文件名full结尾的文件&#xff09;&#xff1a;Builds - CODEX FFMPEG gyan.dev OpenSSL网址&#xff08;建议选择win64的MSI文件&#xff09;&#xff1a;Win3…

maven依赖管理:依赖仓库管理

1、Maven的依赖如何存放管理&#xff1f; Maven中存在依赖组件&#xff08;常用的是jar包、war包、pom等&#xff0c;也可把Zip包等通过POM文件定义为依赖组件&#xff09;的地方称为仓库&#xff08;Repository&#xff09;。 在Maven中&#xff0c;仓库有三种类型&#xff1…

CSS中grid网格布局(秒懂如何实现网格布局)-菜鸟教程

目录 一、概念 二、使用 1.网格元素 2.display属性 3.网格轨道 4.fr 单位 5.网格单元 6.网格区域 7.网格列与行 8.CSS 网格属性 三、网格容器 display&#xff1a; grid-template-columns 和 grid-template-rows&#xff1a; grid-gap、grid-row-gap 和 grid-column-…

如何使用SQL注入工具?

前言 今天来讲讲SQL注入工具&#xff0c;sqlmap。如何使用它来一步步爆库。 sqlmap官方地址如下。 sqlmap: automatic SQL injection and database takeover tool 前期准备&#xff0c;需要先安装好docker、docker-compose。 一个运行的后端服务&#xff0c;用于写一个存在…

计算机网络-TCP断开连接阶段错误应对机制

连接断开阶段 四次挥手机制&#xff1a;TCP连接的断开需要四次挥手&#xff0c;这是因为双方都需要独立地关闭数据传输。第二次和第三次挥手不能合并&#xff0c;因为在回复第二次挥手的时候&#xff0c;可能还有数据没有接收完成&#xff0c;所以需要先回复ACK报文&#xff0c…

【U8+】打开固定资产卡片,提示:运行时错误‘91’,未设置对象变量或with block变量。

【问题描述】 用友U8软件&#xff0c;固定资产模中打开某张卡片后&#xff0c; 提示&#xff1a;运行时错误‘91’&#xff0c;未设置对象变量或with block变量。 Ps&#xff1a;但不是所有卡片打开的时候都会提示&#xff0c;有的正常。 【解决方法】 跟踪数据库后&#xff…

SpringBoot入门(Hello World 项目)

SpringBoot关键结构 1.2.1 Core Container The Core Container consists of the Core, Beans, Context, and Expression Language modules. The Core and Beans modules provide the fundamental parts of the framework, including the IoC and Dependency Injection featur…

C语言易错知识点(3):字符数组的修改、sscanf、sprintf

字符数组是一个很细节的语法&#xff0c;涉及很多知识点&#xff0c;这篇文章我主要分享一下如何理解字符数组&#xff0c;以及对应的sscanf、sprintf有什么用 1.字符数组的初始化以及内容修改易错点 字符数组的初始化方式有两种&#xff0c;一种是直接用字符串进行初始化&am…

每日一题---OJ题: 相交链表

片头 嗨! 小伙伴们,大家好! 今天我们来一起学习这道OJ题---相交链表,准备好了吗? Ready Go! ! ! emmm,看这道题好像不怎么难,我们一起画图分析分析 上图中,A链表有5个结点,分别为 a1,a2,c1,c2,c3 ; B链表有6个结点,分别为 b1,b2,b3,c1,c2,c3 ; A链表和B链表在c1结点相交 …

渗压计在测压管与测井中的安装方法

在地下水动态监测与工程安全评估中&#xff0c;渗压计扮演着至关重要的角色。它能够精准地测量地下水压力的变化&#xff0c;为工程师提供决策依据。本文将详细阐述在测压管或测井中如何正确安装渗压计&#xff0c;以确保其准确度和可靠性。 一、建立零读数并浸透透水石 在安装…

PandasAI的应用与实战解析(一):环境安装、运行demo

文章目录 1.源码包下载、明确依赖版本2.安装python依赖3.运行demo 本博客源码仓库地址&#xff1a;gitlab&#xff0c;本篇博客对应01分支python版本为3.10.x 什么是PandasAI&#xff1f;一句话总结的话&#xff0c;PandasAI就是一个结合了Pandas和AI的开源工具&#xff0c;更…

windwos安全加固

一、账号管理 按用户类型分配账号 目的&#xff1a;根据系统要求&#xff0c;设定不同账户和组&#xff0c;管理员、数据库 sa、审计用户、来宾用户等 实施方法&#xff1a; 打开本地用户和计算机管理器 ​ 1.打开运行&#xff0c;输入lusrmgr.msc 2.根据用户要求将账户加入…

秋招算法刷题7

20240410 1.接雨水 方法一&#xff0c;动态规划&#xff0c;时间复杂度O&#xff08;n^2&#xff09;&#xff0c;空间复杂度O&#xff08;n&#xff09; public int trap(int[] height) { int nheight.length; if(n0){ return 0; } …

java:字符集和字符流

字符集 规定了字符和二进制之间对应关系的一张表 字节是计算机最基本的存储单位 字符则是通过字符组成和编码而成的文本 常见字符集 1,ASCII字符集 基础字符编码标准,包含128个字符,只包括英文字母,数字和一些常见的符号 一个字节表示一个字符 所有的字符集均兼容ASCII…

open-sora

Open-Sora&#xff0c;高效复现类Sora视频生成方案开源&#xff01;魔搭社区最佳实践教程来啦&#xff01;https://mp.weixin.qq.com/s/WMQIDgZs2MBPGtx18XSXgw Open-Sora开源方案讲解开源但“平替”的方案。https://mp.weixin.qq.com/s/nPYCzgBA7hIsPZ6PCyXxKQOpen-Sora/docs…

数据分析案例(一):地区收入的PCA主成分分析

练习1 地区收入的PCA主成分分析 0.变量说明 1.导包操作 核心思路&#xff1a;导入基础数据操作库包&#xff0c;PCA、k-means 库包&#xff0c;数据可视化库包 import pandas as pd import numpy as np from sklearn.decomposition import PCA from sklearn.preprocessing i…