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

C++练习之插入删除

 

#include <iostream>
#include <ctime>
#include <cstring>
#include<cstdlib>
using namespace std;typedef struct bookInfo
{char name[10];float price;int num;
}BOOKINFO;// p: 结构体数组首元素地址
// n: 有效图书数量
void Print(const BOOKINFO *p,int n)
{for (int i = 0; i < n; i++){cout<<"第"<<i+1<<"本书的信息为:"<<"名字:"<<p[i].name<<",价格:"<<p[i].price<<",数量"<<p[i].num<<endl;}}// p:结构体数组首元素地址
// p_info:要插入的图书信息
// location: 插入的位置
// n: 有效图书数量
void Insert(BOOKINFO *p,BOOKINFO *p_info,int location,int *size)
{BOOKINFO *p_i=p;//有效数量+1*size +=1;//将指针移动到最后一个有效元素位置p_i +=*size;while (p_i>p+location){*p_i=*(p_i-1);// 将前面一个元素信息覆盖当前元素信息p_i--;// 从后往前遍历赋值}*(p+location)=*p_info; // 将要插入的图书信息覆盖掉要插入位置元素信息
}// p:结构体数组首元素地址
// location: 删除的位置
// n:有效图书数量
void Delete(BOOKINFO *p,int location,int* size)
{BOOKINFO *p_i=p;//将指针移动到要删除的位置p_i +=location;//  有效数量-1*size -=1;while (p_i<p+ *size){*p_i=*(p_i+1);//  把下一个位置的元素信息覆盖掉当前位置的元素信息p_i++;}// 将最后一个位置的元素信息清空memset(p+ *size,0,sizeof(BOOKINFO));
}
int main()
{int i=0;BOOKINFO *p=new BOOKINFO[10];//先清空memset(p,0,sizeof(BOOKINFO)*10);do{cout<<"请输入第"<<i+1<<"个图书信息:";cin>>p[i].name>>p[i].price>>p[i].num;i++;} while (i<5);int n=5;Print(p,n);//插入BOOKINFO *p_info=new BOOKINFO;cout<<"请输入要插入的图书信息";cin>>p_info->name>>p_info->price>>p_info->num;int location=0;cout<<"请输入要插入的位置";cin>>location;Insert(p,p_info,location,&n);Print(p,n);cout<<"请输入要删除的位置:";cin>>location;Delete(p,location,&n);Print(p,n);delete p_info;p_info=NULL;delete[] p;p=NULL;return 0;
}

http://www.lryc.cn/news/416711.html

相关文章:

  • 【LeetCode】238. 除自身以外数组的乘积
  • Excel公式与函数(运算符,计算限制,错误检查)(一)
  • 用AI助手写程序
  • 动手学深度学习7.2 使用块的网络(VGG)-笔记练习(PyTorch)
  • SolidityFoundry ERC4626
  • 大模型时代的操作系统:融合 Rust 和大模型,打造 AI 操作系统
  • 【ML】为什么要做batch normlization,怎么做batch normlization
  • 【C++指南】命名空间
  • RocketMQ Dashboard安装
  • 前端web开发HTML+CSS3+移动web(0基础,超详细)——第3天
  • 认识MySQL
  • 尚品汇-创建ES索引库(二十七)
  • 设计模式-六大原则
  • MyBatis搭建和增删改查
  • 【一图学技术】6.反向代理 vs API网关 vs 负载均衡的原理和使用场景
  • python爬虫番外篇 | Reuqests库高级用法(1)
  • 【链表OJ】常见面试题 3
  • Linux学习笔记9(Linux包管理)
  • 论文阅读《Geometric deep learning of RNA structure》
  • 宏集方案 | 传统建筑智能化改造,迈向物联新时代
  • 如果服务器更改Web端口会减少被攻击的风险吗?
  • vim列编辑模式
  • 如何实现pxe安装部署
  • 机器学习常见模型
  • 【python案例】基于Python 爬虫的房地产数据可视化分析设计与实现
  • 如何在Python中诊断和解决内存溢出问题
  • 什么是爬虫软件?这两个爬虫神器你必须要试试
  • 记录|MVS和VM软件使用记录
  • 算法通关:014_1:用栈实现队列
  • 【C#】Random