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

C语言之通讯录的实现

在这里插入图片描述

通讯录实现所需头文件和源文件

Contact.h的功能

声明函数和创建结构体变量

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <assert.h>
#define MAX 1000
#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_PHONE 12
#define MAX_ADDRESS 30
#define DEFAULT_SZ 3
#define INTC_SZ 2
typedef struct PeoInform
{char name[MAX_NAME];int age;char sex[MAX_SEX];char phone[MAX_PHONE];char address[MAX_ADDRESS];
}PeoInform;//静态
//typedef struct Contact
//{
//    PeoInform data[MAX];
//    int size;
//    
//}Contact;typedef struct Contact
{PeoInform* data;int size;int capacity;
}Contact;void InitContact(Contact* pc);
void AddContact(Contact* pc);
void ShowContact(const Contact* pc);
void DelContact(Contact* pc);
void SearchContact(const Contact* pc);
void MoidfyContact(Contact* pc);
void SortContact(Contact* pc);
void  DerstoryContact(Contact* pc);
void SaveContact(Contact* pc);
void LoadCntact(Contact* pc);

Contact.c

设定通讯录所需的功能和函数的定义

void InitContact(Contact* pc);//初始化函数
void AddContact(Contact* pc);//增加用户
void ShowContact(const Contact* pc);//显示通讯录信息·
void DelContact(Contact* pc);//删除用户信息
void SearchContact(const Contact* pc);//搜索通讯录
void MoidfyContact(Contact* pc);//修改用户信息
void SortContact(Contact* pc);//排序通讯录
void DerstoryContact(Contact* pc);//因动态申请内存所以释放内存
void SaveContact(Contact* pc);//通讯录信息保存到文件
void LoadCntact(Contact* pc);//把文件保存到通讯录中

void InitContact(Contact* pc);

void InitContact(Contact* pc)
{//动态版memset(pc->data, 0, sizeof(pc->data));//第一个参数是起始地址pc->size = 0;pc->capacity = DEFAULT_SZ;PeoInform* ptr= (PeoInform*)calloc(DEFAULT_SZ,sizeof(PeoInform));if (ptr == NULL){perror("InitContact::calloc");return;}pc->data = ptr;//加载文件信息到通讯录//LoadContact(pc);
}

void AddContact(Contact* pc);

void AddContact(Contact* pc)
{assert(pc);check_capacity(pc);printf("请输入名字\n");scanf("%s", pc->data[pc->size].name);printf("请输入年龄\n");scanf("%d", &(pc->data[pc->size].age));printf("请输入性别\n");scanf("%s", pc->data[pc->size].sex);printf("请输入电话\n");scanf("%s", pc->data[pc->size].phone);printf("请输入地址\n");scanf("%s", pc->data[pc->size].address);pc->size++;printf("添加成功\n");
}

``

void ShowContact(const Contact* pc);

	void ShowContact(const Contact * pc){if (pc->size == 0){printf("通讯录为空\n");}else{int i = 0;printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");for (i = 0; i < pc->size; i++){printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].phone,pc->data[i].address);}}}

void DelContact(Contact* pc);

static int FindByName(const Contact* pc, char name[MAX_NAME])//用于函数内部所以设置为静态
{int i = 0;for (int i = 0; i < pc->size; i++){if (0 == strcmp(pc->data[i].name, name)){return i;}}return -1;
}void DelContact(Contact* pc)
{char name[MAX_NAME];printf("请输入要删除人的名字>");scanf("%s", name);int pos = FindByName(pc,name);if (pos == -1){printf("查询不到联系人\n");}else{int j = 0;for (j = pos; j < pc->size; j++);}
}

void SearchContact(const Contact* pc);

static int FindByName(const Contact* pc, char name[MAX_NAME])//用于函数内部所以设置为静态
{int i = 0;for (int i = 0; i < pc->size; i++){if (0 == strcmp(pc->data[i].name, name)){return i;}}return -1;
}
void SearchContact(const Contact* pc)
{char name[MAX_NAME];printf("请输入查找人的名字\n");scanf("%s", name);int pos = FindByName(pc, name);if (pos == -1){printf("要查找人不存在\n");}else{printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",pc->data[pos].name,pc->data[pos].age,pc->data[pos].sex,pc->data[pos].phone,pc->data[pos].address);}
}

void MoidfyContact(Contact* pc);

void MoidfyContact(Contact* pc)
{char name[MAX_NAME];printf("请输入修改联系人的名字>");scanf("%s", name);int pos = FindByName(pc, name);if (pos == -1){printf("要修改人的名字");}else{printf("请输入名字\n");scanf("%s", pc->data[pc->size].name);printf("请输入年龄\n");scanf("%d", &(pc->data[pc->size].age));printf("请输入性别\n");scanf("%s", pc->data[pc->size].sex);printf("请输入电话\n");scanf("%s", pc->data[pc->size].phone);printf("请输入地址\n");scanf("%s", pc->data[pc->size].address);printf("修改完成\n");}
}

void SortContact(Contact* pc);

	void SortContact(Contact* pc){if (pc->size == 0){printf("通讯录没有联系人,请添加\n");}for (int i = 0; i < pc->size-1; i++){for (int j = 0; j < pc->size - 1 - i; j++){if (strcmp((pc->data[j].name), (pc->data[j + 1].name) )> 0){PeoInform tmp;tmp = pc->data[j];pc -> data[j] = pc->data[j+1];pc->data[j+1] = tmp;}}printf("排序成功\n");}}

void DerstoryContact(Contact* pc);

void  DerstoryContact(Contact* pc)
{free(pc->data);pc->data = NULL;pc->capacity = 0;pc->size = 0;pc = NULL;
}

void SaveContact(Contact* pc);

void SaveContact(Contact* pc)//保存文件信息{FILE * pf = fopen("contact.txt", "wb");// 为了输出数据,打开一个二进制文件if (NULL == pf){perror("SaveContact");//打开失败就不用关闭文件了}else{int i = 0;for (i = 0; i < pc->size; i++){/fwrite(pc->data + i, sizeof(PeoInform), 1, pf);//1.结构体地址,一个元素占多少字节,多少个元素,写到pf这个文件}//一次写一个到pf所指文件fclose(pf);pf = NULL;printf("保存成功\n");}}

void LoadCntact(Contact* pc);

	void LoadContact(Contact* pc){//把文件的内容放在通讯录中FILE* pf = fopen("contact.txt","rb"); //为了输入数据,打开一个二进制文件if (pf == NULL){perror("LoadContact");}else//读数据{PeoInform tmp = { 0 };int i = 0;//正常读到1返回1 没读到返0while (fread(&tmp, sizeof(PeoInform), 1, pf))//{check_capacity(pc);pc->data[i] = tmp;pc->size++;i++;}}fclose(pf);pf = NULL;}

contact.c的综合实现

#include "Contact.h"
void check_capacity(Contact* pc)
{if (pc->size = pc->capacity){PeoInform* str = (PeoInform*)realloc(pc->data, (pc->capacity + INTC_SZ) * sizeof(PeoInform));if (str == NULL){perror("check_capacity::realloc");return;}pc->data = str;pc->capacity += INTC_SZ;printf("增容成功");}
}//静态
//void InitContact(Contact* pc)
//{
//	memset(pc->data, 0, sizeof(pc->data));//第一个参数是起始地址
//	pc->size = 0;
//}//动态
void InitContact(Contact* pc)
{memset(pc->data, 0, sizeof(pc->data));//第一个参数是起始地址pc->size = 0;pc->capacity = DEFAULT_SZ;PeoInform* ptr= (PeoInform*)calloc(DEFAULT_SZ,sizeof(PeoInform));if (ptr == NULL){perror("InitContact::calloc");return;}pc->data = ptr;//加载文件信息到通讯录//LoadContact(pc);
}void AddContact(Contact* pc)
{assert(pc);check_capacity(pc);printf("请输入名字\n");scanf("%s", pc->data[pc->size].name);printf("请输入年龄\n");scanf("%d", &(pc->data[pc->size].age));printf("请输入性别\n");scanf("%s", pc->data[pc->size].sex);printf("请输入电话\n");scanf("%s", pc->data[pc->size].phone);printf("请输入地址\n");scanf("%s", pc->data[pc->size].address);pc->size++;printf("添加成功\n");
}static int FindByName(const Contact* pc, char name[MAX_NAME])
{int i = 0;for (int i = 0; i < pc->size; i++){if (0 == strcmp(pc->data[i].name, name)){return i;}}return -1;
}void DelContact(Contact* pc)
{char name[MAX_NAME];printf("请输入要删除人的名字>");scanf("%s", name);int pos = FindByName(pc,name);if (pos == -1){printf("查询不到联系人\n");}else{int j = 0;for (j = pos; j < pc->size; j++);}
}void SearchContact(const Contact* pc)
{char name[MAX_NAME];printf("请输入查找人的名字\n");scanf("%s", name);int pos = FindByName(pc, name);if (pos == -1){printf("要查找人不存在\n");}else{printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",pc->data[pos].name,pc->data[pos].age,pc->data[pos].sex,pc->data[pos].phone,pc->data[pos].address);}
}void MoidfyContact(Contact* pc)
{char name[MAX_NAME];printf("请输入修改联系人的名字>");scanf("%s", name);int pos = FindByName(pc, name);if (pos == -1){printf("要修改人的名字");}else{printf("请输入名字\n");scanf("%s", pc->data[pc->size].name);printf("请输入年龄\n");scanf("%d", &(pc->data[pc->size].age));printf("请输入性别\n");scanf("%s", pc->data[pc->size].sex);printf("请输入电话\n");scanf("%s", pc->data[pc->size].phone);printf("请输入地址\n");scanf("%s", pc->data[pc->size].address);printf("修改完成\n");}
}void ShowContact(const Contact * pc){if (pc->size == 0){printf("通讯录为空\n");}else{int i = 0;printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n", "名字", "年龄", "性别", "电话", "地址");for (i = 0; i < pc->size; i++){printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].phone,pc->data[i].address);}}}void SortContact(Contact* pc){if (pc->size == 0){printf("通讯录没有联系人,请添加\n");}for (int i = 0; i < pc->size-1; i++){for (int j = 0; j < pc->size - 1 - i; j++){if (strcmp((pc->data[j].name), (pc->data[j + 1].name) )> 0){PeoInform tmp;tmp = pc->data[j];pc -> data[j] = pc->data[j+1];pc->data[j+1] = tmp;}}printf("排序成功\n");}}void  DerstoryContact(Contact* pc){free(pc->data);pc->data = NULL;pc->capacity = 0;pc->size = 0;pc = NULL;}void SaveContact(Contact* pc){FILE * pf = fopen("contact.txt", "wb");if (NULL == pf){perror("SaveContact");}else{int i = 0;for (i = 0; i < pc->size; i++){fwrite(pc->data + i, sizeof(PeoInform), 1, pf);}fclose(pf);pf = NULL;printf("保存成功\n");}}void LoadContact(Contact* pc){FILE* pf = fopen("contact.txt","rb"); if (pf == NULL){perror("LoadContact");}else{PeoInform tmp = { 0 };int i = 0;while (fread(&tmp, sizeof(PeoInform), 1, pf)){check_capacity(pc);pc->data[i] = tmp;pc->size++;i++;}}fclose(pf);pf = NULL;}

test.h

#include "Contact.h"void menu()
{printf("*********************************\n");printf("**      1. 添加联系人          **\n");printf("**      2. 删除联系人          **\n");printf("**      3. 查找联系人          **\n");printf("**      4. 修改联系人          **\n");printf("**      5. 显示所有联系人      **\n");printf("**      6. 按姓名排序联系人    **\n");printf("**      0. exit                **\n");printf("*********************************\n");
}
void test()
{int input = 0;Contact con;InitContact(&con);do{menu();printf("请选择:>");scanf("%d", &input);switch (input){case 1:AddContact(&con);break;case 2: DelContact(&con);break;case 3:SearchContact(&con);break;case 4:MoidfyContact(&con);break;case 5:ShowContact(&con);break;case 6:SortContact(&con);break;case 0:DerstoryContact(&con);printf("退出通讯录\n");break;default:printf("选择错误\n");break;}} while (input);
}
int main()
{test();return 0;
}

在这里插入图片描述

相关文章:

C语言之通讯录的实现

通讯录实现所需头文件和源文件 Contact.h的功能 声明函数和创建结构体变量 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <string.h> #include <stdlib.h> #include <assert.h> #define MAX 1000 #define MAX_NAME 20 #define MAX…...

手把手教大家在 gRPC 中使用 JWT 完成身份校验

文章目录1. JWT 介绍1.1 无状态登录1.1.1 什么是有状态1.1.2 什么是无状态1.2 如何实现无状态1.3 JWT1.3.1 简介1.3.2 JWT数据格式1.3.3 JWT 交互流程1.3.4 JWT 存在的问题2. 实践2.1 项目创建2.2 grpc_api2.3 grpc_server2.4 grpc_client3. 小结上篇文章松哥和小伙伴们聊了在 …...

VSCode远程连接服务器

工作使用服务器的jupyter&#xff0c;直到有一天服务器挂了&#xff0c;然而&#xff0c;代码还没有来得及备份。o(╥﹏╥)o VScode远程连接服务器&#xff0c;使用服务器的资源&#xff0c;代码可以存在本地&#xff0c;可以解决上述困境。 1.官网下载VSCode.网址https://cod…...

【C++】-- 异常

目录 C语言传统的处理错误的方式 C异常概念 异常的使用 异常的抛出和捕获 自定义异常体系 异常的重新抛出 异常安全 异常规范&#xff08;C期望&#xff09; C标准库的异常体系 异常的优缺点 C异常的优点 C异常的缺点 总结 C语言传统的处理错误的方式 传统的错误…...

Java中的Stack与Queue

文章目录一、栈的概念及使用1.1 概念1.2 栈的使用1.3 栈的模拟实现二、队列的概念及使用2.1 概念2.2 队列的使用2.3 双端队列(Deque)三、相关OJ题3.1 用队列实现栈。3.2 用栈实现队列。总结一、栈的概念及使用 1.1 概念 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在…...

xilinx FPGA在线调试方法总结(vivado+ila+vio)

本文主要介绍xilinx FPGA开发过程中常用的调试方法&#xff0c;包括ILA、VIO和TCL命令等等&#xff0c;详细介绍了如何使用。一、FPGA调试基本原则根据实际的输出结果表现&#xff0c;来推测可能的原因&#xff0c;再在模块中加ILA信号&#xff0c;设置抓信号条件&#xff0c;逐…...

自动化测试——css元素定位

文章目录一、css定位场景二、css相对定位的优点三、css的调试方法1、表达式中含有字符串&#xff1a;表达式中的引号一定和外面字符串的引号相反四、css基础语法1、标签定位2、class定位特别注意&#xff1a;当class类型的属性值包含多个分割值&#xff0c;$(.s_tab s_tab_1z9n…...

ChatGPT可能马上取代你,这是它能做的十个工作

ChatGPT 的横空出世,在业界掀起了惊涛骇浪。专家表示,ChatGPT 和相关人工智能技术可能会威胁到一些工作岗位,尤其是白领工作。 自去年11月发布以来,新型聊天机器人模型 ChatGPT 已经被用于各种各样的工作:撰写求职信、编写儿童读物,甚至帮助学生在论文中作弊。谷歌公司发…...

ubuntu转储coredump

方法一&#xff1a; 输入以下命令即可,其中${USER}为自己电脑的用户名&#xff1a; ulimit -c unlimited echo "/home/${USER}/core.%p" > /proc/sys/kernel/core_pattern 方法二&#xff1a; Disable apport : sudo systemctl stop apport.servicesudo system…...

基于单片机的毕业设计推荐

** 2023基于单片机的毕业设计推荐&#xff1a; ** 1、基于51单片机的多功能门禁系统&#xff08;低端、功能限制较大&#xff09;。 2、基于单片机的多功能实时时钟。 3、基于单片机的音乐播放器。 4、基于STM32单片机的多功能门禁系统&#xff08;高端、没有限制&#xff09…...

APP测试中ios和androis的区别,有哪些注意点

目录 一、运行机制不同 二、对app内存消耗处理方式不同 三、后台制度不同 四、最高权限指令不同 五、推送机制不同 六、抓取方式不同 七、灰度发版机制不同 八、审核机制不同 总结感谢每一个认真阅读我文章的人&#xff01;&#xff01;&#xff01; 重点&#xff1a;…...

使用 Xcode 创建第一个 Objective-C 命令行程序 HelloWorld

总目录 iOS开发笔记目录 从一无所知到入门 文章目录创建项目运行项目&#xff0c;查看日志输出同一项目下新增子目录&#xff0c;切换要运行的 Target创建项目 打开 Xcode &#xff0c;Create a new Xcode project 接下来的默认界面&#xff1a; 切换到 macOS 下&#xff…...

【蓝桥杯集训8】哈希表专题(3 / 3)

目录 手写哈希表 1、开放寻址法 2、拉链法 字符串前缀哈希表法 2058. 笨拙的手指 - 哈希表 秦九韶算法&#xff08;进制转换&#xff09; 枚举 秦九韶算法——将x进制数转化为十进制数 手写哈希表 活动 - AcWing 1、开放寻址法 设 h(x)k&#xff0c;也就是 x 的哈希值…...

Java Scanner 类,超详细整理,适合新手入门

目录 一、什么是 Java Scanner 类&#xff1f; 二、引用数据类型 1、引用数据类型的定义 三、Scanner 类有哪些常用方法&#xff1f; hasNext()用法 四、next() 与 nextLine() 区别 next(): nextLine()&#xff1a; 五、使用 next 方法 五、使用 nextLine方法 一、什…...

干货 | 中小企业选型 Elasticsearch 避坑指南

1、线上常见问题在我线下对接企业或线上交流的时候&#xff0c;经常会遇到各种业务场景不同的问题。比如&#xff0c;常见问题归类如下&#xff1a;常见问题1&#xff1a;ES 适合场景及架构选型问题。公司的核心业务是做企业员工健康管理&#xff0c;数据来自电子化后的员工体检…...

全局组件和局部组件

全局组件第一种定义方法&#xff1a;A、创建自己的组件&#xff1a;Loading.vueB、在main.js文件中引入组件并注册import Vue from vue import App from ./App.vue import * as filters from ./filterimport quanjuzujian from ./components/quanjuzujian.vueVue.component(qua…...

提取括号中的内容

正则能解决不嵌套的括号内容提取问题遇到一个问题&#xff0c;就是需要提取字符串中每一个中括号里的内容&#xff0c;在网上搜了一下&#xff0c;发现用正则表达式(\[[^\]]*\])可以提取中括号中的内容&#xff0c;以下面文本为匹配对象&#xff1a;PerformanceManager[第1个中…...

数据结构-算法的空间复杂度(1.2)

目录 1.空间复杂度 1.1 例子 1.2 空间的特殊性质 写在最后&#xff1a; 1.空间复杂度 空间复杂度也是一个数学表达式&#xff0c; 是对一个算法在运行过程中临时占用存储空间大小的量度。 他也是用大O渐进表示法。 1.1 例子 例1&#xff1a; 冒泡排序&#xff1a; v…...

【总结】python3启动web服务引发的一系列问题

背景 在某行的实施项目&#xff0c;需要使用python3环境运行某些py脚本。 由于行内交付的机器已自带python3 &#xff0c;没有采取自行安装python3&#xff0c;但是运行python脚本时报没有tornado module。 错误信息 ModuleNotFoundError&#xff1a;No module named ‘torn…...

Linux:基于libevent读写管道代码,改进一下上一篇变成可以接收键盘输入

对上一篇进行改进&#xff0c;变成可以接收键盘输入&#xff0c;然后写入管道&#xff1a; 读端代码&#xff1a; #include <stdlib.h> #include <stdio.h> #include <unistd.h> #include <sys/types.h> #include <sys/stat.h> #include <s…...

C语言格式化输出总结:%d,%c,%s,%f, %lf,%m.nd,%m.nf,%m.ns 以及sprintf函数

凡事发生必将有益于我&#xff0c;高手&#xff0c;从来都不仅仅是具备某种思维的人&#xff0c;而是那些具备良好学习习惯的人&#xff0c;成为高手&#xff0c;无他&#xff0c;手熟尔&#xff01;加油在最近的学习之中&#xff0c;对于格式化输出这个知识点&#xff0c;这里…...

Nginx之反向代理、负载均衡、动静分离。

Nginx之反向代理、负载均衡、动静分离。 1、Nginx是啥&#xff1f; 轻量级Web服务器、反向代理服务器、电子邮件&#xff08;IMAP/POP3&#xff09;代理服务器 在 BSD-like 协议下发行、占内存少、并发高&#xff08;同时处理请求能力&#xff09;。 2、安装 官网&#xf…...

0401不定积分的概念和性质-不定积分

文章目录1 原函数与不定积分的概念1.1 原函数1.2 原函数存在定理1.3 不定积分2 不定积分的性质3 基本积分表4 例题后记1 原函数与不定积分的概念 1.1 原函数 定义1 如果在区间I上&#xff0c;可导函数F(x)的导航为f(x)&#xff0c;即对任一x∈Ix\in Ix∈I&#xff0c;都有 F′…...

数组中的各种迭代API方法手写

js的数组上有很多实用的方法&#xff0c;不论是在遍历数组上&#xff0c;还是在操作数组内元素上&#xff0c;它有许多不同的遍历数组的方法&#xff0c;同时它还有着可以直接操作数组中间元素的方法。 接下来&#xff0c;我来带大家手写数组里的 遍历方法 。 Array.forEach(…...

详解量子计算:相位反冲与相位反转

前言 本文需要对量子计算有一定的了解。需要的请翻阅我的量子专栏&#xff0c;这里不再涉及基础知识的科普。 量子相位反冲是什么&#xff1f; 相位反转&#xff08;phase kickback&#xff09;是量子计算中的一种现象&#xff0c;通常在量子算法中使用&#xff0c;例如量子…...

C++——C++11第三篇

目录 包装器 function包装器 bind 包装器 function包装器 function包装器 也叫作适配器。C中的function本质是一个类模板&#xff0c;也是一个包装器。 上面的程序验证&#xff0c;我们会发现useF函数模板实例化了三份。 包装器可以很好的解决上面的问题 &#xff0c;让它只实…...

180 2 22222

选择题(共180题,合计180.0分) 1. 在项目开工会议期间&#xff0c;项目发起人告诉产品负责人和团队项目章程即将完成。然而&#xff0c;由于存在在紧迫的期限内满足政府监管要求的压力&#xff0c;发起人希望立即开始工作。产品负责人下一步应该做什么&#xff1f; A 告诉发起人…...

成人高考初中毕业能报名吗 需要什么条件

初中学历的人员不能直接报名成人高考&#xff0c;考生需要有普通高中&#xff0c;职业高中&#xff0c;中专毕业证等高中同等学力就可以进行报名&#xff0c;在报名期间登陆所在省的教育考试院的成人高考报名入口进行报考。成人高考报名条件是什么1、遵守宪法和法律。2、国家承…...

ChatGPT初体验

ChatGPT初体验 前言 嘿嘿&#xff0c;最近啊AI ChatGPT刷新各大网站&#xff0c;对于我们国人而将很不友好&#xff0c;真的太不友好了。我呢在去年open AI发布的时候就有所关注&#xff0c;那个时候还没有像现在这样火热。谁知道短短几个月便传遍大街小巷。 一、什么是chatG…...

ChatGPT概念狂飙!究竟魅力何在?

原文&#xff1a;http://www.btcwbo.com/6988.html 近期&#xff0c;ChatGPT引领的人工智能概念在资本市场一路狂飙&#xff0c;AIGC题材持续发酵。截至2月7日&#xff0c;Wind ChatGPT指数今年以来累计上涨超50%&#xff0c;汉王科技、海天瑞声、云从科技等概念股股价已经翻倍…...