IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 数据结构课上练习(二) -> 正文阅读

[数据结构与算法]数据结构课上练习(二)

输入要求

输出要求

代码运行结果示例


完整代码:

#include<stdio.h>
#include<malloc.h>
#define N 10
//1.定义结构体Book(结点)
typedef struct {
	char id[N];	//书号
	char name[N]; //书名
	float price; //书价 
}Book; 

//2.定义顺序表
typedef struct{
	//数组(存放数据元素,即每本书)
	Book *elem;
	//数组长度(可存放多少数据元素)
	int length;
}SqList;

//3.初始化顺序表 
void InitSqList(SqList *L){
	//为顺序表中每个数据元素开辟空间
	L->elem=(Book*)malloc(sizeof(Book)*N);
	//初始数组长度为0
	L->length=0; 
}

//4.创建顺序表(创建n个数据元素)
void CreateSqList(SqList *L,int n){
	int i=0;
	//循环输入n个数据元素
	for(;i<n;i++){
		printf("书号,书名,书价:");
		scanf("%s %s %f",&L->elem[i].id,&L->elem[i].name,&L->elem[i].price);
		//表长增加  
		L->length++; 
	} 
}

//5.输出顺序表2
void PrintSqList(SqList *L){
	int i=0;
	for(;i<L->length;i++){
		printf("第%d本书的书号,书名,书价:",i+1);
		//输出每本书的书号,书名,书价 
		printf("%s %s %.2f\n",L->elem[i].id,L->elem[i].name,L->elem[i].price);
	}
}

//6.插入操作
//插入位置 i(对应下标i-1)将此位置空出来 
//插入数据元素b 
int InsertSqList(SqList *L,int i,Book b){
	//判断顺序表是否已满 
	if(L->length==N)
		return -1;
	//判断插入位置是否合法
	if(i<1 || i>L->length)
		return -1;
		
	int j;
	//插入位置合法 
	if(i<=L->length && i>0){
		//将表尾到插入位置i(对应下标i-1)的元素依次向后移动一位
		for(j=L->length-1;j>=i-1;j--){	
		L->elem[j+1]=L->elem[j];
		} 
		//插入操作,将数据元素b插入位置i (对应下标i-1)
		L->elem[i-1]=b;
		//表长+1 
		L->length++;
 	}
}

//主函数
int main(){
	int n,i;	//输入n个数据元素,插入位置i (对应下标i-1)
	Book b;  	//定义一本书b 
	SqList L;   //定义表L
	
	InitSqList(&L); //初始化 InitSqList(SqList *L)
	//为顺序表添加的数据元素个数 
	printf("为顺序表添加的数据元素个数:"); 
	scanf("%d",&n);
	//创建含有n个数据元素的顺序表 CreateSqList(SqList *L,int n)
	CreateSqList(&L,n);	
	//输出顺序表 PrintSqList(SqList *L)
	PrintSqList(&L);	
	//向顺序表插入1个数据元素,插入位置 
	printf("向顺序表插入1本书籍信息,其插入位置为:"); 
	scanf("%d",&i);
	//输入插入的数据元素的各数据项
	printf("输入要插入的书籍的书号,书名,书价:");
	scanf("%s %s %f",&b.id,&b.name,&b.price);
	//插入操作 
	InsertSqList(&L,i,b); //插入数据元素 InsertSqList(SqList *L,int i,Book b)
	//输出插入后的顺序表 
	PrintSqList(&L);	//输出顺序表 PrintSqList(SqList *L)
	return 0;
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-10-09 16:31:37  更:2021-10-09 16:32:49 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 17:56:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码