任务描述 本关任务:定义一个包含图书信息(书号、书名、价格)的顺序表,读入相应的图书数据完成图书信息表的创建,逐行输出排序后每本图书的信息。 编程要求 输入 输入n+1行,前n行是n本图书的信息(书号、书名、价格),每本图书信息占一行,书号、书名、价格用空格分隔,价格之后没有空格。最后第n+1行是输入结束标志:0 0 0(空格分隔的三个0)。其中书号和书名为字符串类型,价格为浮点数类型。 输出 总计n行,每行是一本图书的信息(书号、书名、价格),书号、书名、价格用空格分隔。其中价格输出保留两位小数。#include<iostream>#include<string.h>#include<iomanip>#define OK 1#define ERROR 0#define OVERFLOW -2#define MAXSIZE 1000 //图书表可能达到的最大长度using namespace std;typedef struct{//图书信息定义 char no[20]; //图书ISBN char name[50]; //图书名字 float price; //图书价格}Book;typedef struct{//图书表的顺序存储结构类型为SqList Book *elem; //存储空间的基地址 int length; //图书表中当前图书个数}SqList;int InitList_Sq(SqList &L){//构造一个空的顺序表L }int Input_Sq(SqList &L){//顺序表的输入 }int Output_Sq(SqList L){//顺序表的输出 }
时间: 2023-05-20 14:07:08 浏览: 190
本任务要求定义一个顺序表,用于存储图书信息,包括书号、书名和价格。输入时,先输入图书数量n,然后输入n行图书信息,每行包括书号、书名和价格,用空格分隔。最后一行输入结束标志0 0 0。输出时,按照价格从小到大的顺序输出每本图书的信息,每行输出一本图书的信息,包括书号、书名和价格,用空格分隔,价格保留两位小数。
相关问题
本关任务:定义一个包含图书信息(书号、书名、价格)的顺序表,读入相应的图书数据完
成表格输出。
步骤:
1. 定义一个结构体Book,包含三个成员变量:书号、书名、价格。
2. 定义一个顺序表bookList,用于存放Book结构体类型的数据。
3. 读入图书数据,包括书号、书名、价格,并将数据存入bookList中。
4. 输出表格,表格包括三列:书号、书名、价格。可以使用printf函数格式化输出。
5. 完成程序编写并测试。
代码如下:
本关任务:定义一个包含图书信息(书号、书名、价格)的顺序表,读入相应的图书数据来完成图书信息表的创建,然后查找价格最高的图书,输出相应图书的信息。
为了完成这个任务,我们首先需要定义一个表示图书信息的结构体。然后,我们创建一个结构体数组来表示顺序表。接下来,我们将读入图书信息来填充这个顺序表。最后,我们将遍历顺序表以查找价格最高的图书,并输出它的信息。
下面是一个简单的C++代码示例,它实现了上述任务:
```cpp
#include <iostream>
#include <string>
using namespace std;
// 定义图书信息的结构体
struct Book {
int id; // 书号
string title; // 书名
double price; // 价格
};
// 创建图书信息顺序表并输入数据
void createBookList(Book books[], int size) {
cout << "Enter the number of books: ";
int n;
cin >> n;
for (int i = 0; i < n; ++i) {
cout << "Enter book ID, title, and price for book " << i + 1 << ": ";
cin >> books[i].id >> books[i].title >> books[i].price;
}
}
// 查找价格最高的图书并输出信息
void findMostExpensiveBook(Book books[], int size) {
if (size == 0) {
cout << "No books in the list." << endl;
return;
}
int index = 0; // 用于记录价格最高图书的索引
for (int i = 1; i < size; ++i) {
if (books[i].price > books[index].price) {
index = i; // 更新价格最高的图书索引
}
}
cout << "Most expensive book:" << endl;
cout << "ID: " << books[index].id << endl;
cout << "Title: " << books[index].title << endl;
cout << "Price: " << books[index].price << endl;
}
int main() {
int numberOfBooks;
cout << "Enter the total number of books: ";
cin >> numberOfBooks;
// 创建图书信息顺序表数组
Book *bookList = new Book[numberOfBooks];
// 输入图书信息
createBookList(bookList, numberOfBooks);
// 查找并输出价格最高的图书信息
findMostExpensiveBook(bookList, numberOfBooks);
// 释放分配的内存
delete[] bookList;
return 0;
}
```
在这个代码中,我们首先定义了一个`Book`结构体来存储图书信息。然后我们创建了一个`Book`数组`bookList`,并用`createBookList`函数填充了图书数据。之后,我们调用`findMostExpensiveBook`函数来查找价格最高的图书并输出它的详细信息。最后,我们释放了动态分配的内存。
阅读全文