typedef struct { char name[20]; int price; }Book; int book1; #define book (Book*)(&book1); book->price = 0; 为什么会提示应输入表达式
时间: 2024-09-09 20:06:48 浏览: 44
在这段代码中,`typedef struct` 定义了一个名为 `Book` 的结构体,包含一个字符数组 `name` 和一个整数 `price`。然后,变量 `book1` 被声明为 `Book` 类型,并通过 `#define` 把 `book` 定义为指向 `book1` 地址的指针。
当执行 `book->price = 0;` 这一行时,它试图给 `book` 指向的结构体的 `price` 成员赋值。然而,`book` 并不是一个实际的变量,而是一个宏定义,它的值就是 `&book1` 的地址。所以当你直接写 `book->price` 时,编译器会把它解析为 `(*(&book1))->price`,而不是一个可以进行赋值操作的对象。
正确的做法应该是先获取 `book` 所引用的实际 `Book` 结构体实例,然后再访问其成员。例如,如果有一个 `Book` 实例 `myBook`,应该这样操作:
```c
Book myBook;
myBook.price = 0;
```
或者如果你想通过 `book` 来修改 `book1` 的 `price`,你应该这样做:
```c
*book = {0}; // 直接设置整个 Book 对象的值
// 或者
(*book).price = 0; // 仅修改 price 字段
```
编译器的错误信息告诉你应输入一个表达式,意思是你需要提供一个可以直接计算得到值的操作,而不是试图直接对 `book` 进行成员访问。
相关问题
任务描述 本关任务:定义一个包含图书信息(书号、书名、价格)的顺序表,读入相应的图书数据完成图书信息表的创建,逐行输出排序后每本图书的信息。 编程要求 输入 输入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){//顺序表的输出 }
本任务要求定义一个顺序表,用于存储图书信息,包括书号、书名和价格。输入时,先输入图书数量n,然后输入n行图书信息,每行包括书号、书名和价格,用空格分隔。最后一行输入结束标志0 0 0。输出时,按照价格从小到大的顺序输出每本图书的信息,每行输出一本图书的信息,包括书号、书名和价格,用空格分隔,价格保留两位小数。
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_SIZE 100 typedef struct { int book_id; char book_name[50]; float price; } Book; typedef struct { Book books[MAX_SIZE]; int length; } BookList; void input_books(BookList* list, int n) { for (int i = 0; i < n; i++) { printf("请输入第%d本书的信息:\n", i + 1); printf("图书编号:"); scanf("%d", &list->books[i].book_id); printf("书名:"); scanf("%s", list->books[i].book_name); printf("价格:"); scanf("%f", &list->books[i].price); } list->length = n; } void display_books(BookList* list) { printf("图书表中所有图书的相关信息:\n"); for (int i = 0; i < list->length; i++) { printf("图书编号:%d\n", list->books[i].book_id); printf("书名:%s\n", list->books[i].book_name); printf("价格:%f\n", list->books[i].price); } } void insert_book(BookList* list, int pos, Book book) { if (pos < 1 || pos > list->length + 1) { printf("插入位置不合法!\n"); return; } for (int i = list->length - 1; i >= pos - 1; i--) { list->books[i + 1] = list->books[i]; } list->books[pos - 1] = book; list->length++; } void delete_book(BookList* list, int pos) { if (pos < 1 || pos > list->length) { printf("删除位置不合法!\n"); return; } for (int i = pos - 1; i < list->length - 1; i++) { list->books[i] = list->books[i + 1]; } list->length--; } int count_books(BookList* list) { return list->length; } int partition(BookList* list, int low, int high) { Book pivot = list->books[low]; while (low < high) { while (low < high && list->books[high].book_id >= pivot.book_id) high--; list->books[low] = list->books[high]; while (low < high && list->books[low].book_id <= pivot.book_id) low++; list->books[high] = list->books[low]; } list->books[low] = pivot; return low; } void quick_sort(BookList* list, int
) {
if (list->length <= 1) return;
int stack[MAX_SIZE], top = -1;
stack[++top] = 0;
stack[++top] = list->length - 1;
while (top > 0) {
int high = stack[top--];
int low = stack[top--];
int mid = partition(list, low, high);
if (low < mid - 1) {
stack[++top] = low;
stack[++top] = mid - 1;
}
if (mid + 1 < high) {
stack[++top] = mid + 1;
stack[++top] = high;
}
}
}
int main() {
BookList list;
input_books(&list, 3);
display_books(&list);
Book book = { 4, "Data Structures and Algorithms", 45.8 };
insert_book(&list, 2, book);
display_books(&list);
delete_book(&list, 3);
display_books(&list);
int count = count_books(&list);
printf("图书表中共有%d本图书。\n", count);
quick_sort(&list, count);
display_books(&list);
return 0;
}
这是一个图书管理系统的代码,实现了图书的增删查改和快速排序功能。其中Book和BookList为自定义的结构体,分别表示图书和图书表。在主函数中,先输入3本图书的信息,然后显示所有图书的信息,接着在第二个位置插入一本新书并显示所有图书的信息,再删除第三本书并显示所有图书的信息。然后统计图书数量并输出,最后对图书表进行快速排序并输出排序结果。
阅读全文