Ich bin noch neu in der Programmierung. Ich wollte nur fragen, wie ich lineare Suche mit Zeigern machen soll. Ich wollte ein Buchverwaltungsprogramm machen und habe ein Programm mit Zeigern geschrieben.Wie lineare Suche mit Zeigern zu tun?
This is the example of how i want it.
Dies ist die Codierung
#include <iostream>
#define MAX 5
using namespace std;
struct record
{
int id;//stores id
float price;//store price
int qty;//stores quantity
record* next;//reference to the next node
};
record* head;//create empty record
record* tail;//the end of the record
void push(record *& head, record *&tail, int id, float price, int qty)
{
if (head == NULL)
{
record* r = new record;
r->id = id;
r->price = price;
r->qty = qty;
r->next = NULL;//end of the list
head = r;
tail = r;
}
else if (head != NULL && (MAX - 1))
{
record* r = new record;
r->id = id;
r->price = price;
r->qty = qty;
r->next = head;
head = r;
}
}
int pop(record *&head, record *& tail)
{
if (head == NULL)
{
cout << "No record in memory" << endl;
}
else if (head == tail)
{
cout << "The record "<<"ID: " << head->id << "\nPrice: " << head->price << "\nQuantity: " << head->qty << "\n" << "was deleted" << endl; //CORRECTION HERE
}
else
{
record* delptr = new record;
delptr = head;
head = head->next;
cout << "The record " << delptr->id << ", " << delptr->price << ", " << delptr->qty << " was deleted" << endl; //CORRECTION HERE
delete delptr;
}
return 0;
}
void display(record *&head)
{
record* temp = new record; //CORRECTION HERE
temp = head;
if (temp == NULL)
{
cout << "No record in memory" << endl;
}
else
{
cout << "Record : " << endl;
while (temp != NULL)
{
cout <<"\nID: "<< temp->id << "\nPrice: " << temp->price << "\nQuantity: " << temp->qty <<"\n"<< endl; //CORRECTION HERE
temp = temp->next;
}
}
}
int LinearSearch(record *&head) {
}
char menu()
{
char choice;
cout << "\t::MENU::\n" << endl;
cout << "1. Add new record\n" << endl;
cout << "2. Delete record\n" << endl;
cout << "3. Show record\n" << endl;
cout << "4. Quit\n" << endl;
cout << "-----------------------\n" << endl;
cout << "\nEnter selection : " << endl;
cin >> choice;
return choice;
}
int main()
{
record* head;
record* tail;
head = NULL;
tail = NULL;
char choice;
do
{
cout << "---------------------- - \n" << endl;
choice = menu();
switch (choice) { //CORRECTION HERE
case '1':
int id, qty;
float price;
cout << "Enter ID:";
cin >> id; // Please correct yourself here, what is r here, r is not declared anywhere
cout << "\nEnter Price: ";
cin >> price;
cout << "\nEnter Quantity: ";
cin >> qty;
push(head, tail, id, price, qty);
break;
case '2':
pop(head, tail);
break;
case'3':
display(head);
break;
default:
cout << "Quiting...\n";
}
} while (choice != '4');
return 0;
}
Wie kann ich für diese Codierung lineare Suche der Zeiger Code schreiben? Ich habe versucht, Beispiele im gesamten Web zu finden und wenn ich es ausführe, hat es nicht funktioniert, also lasse ich es leer.
Die lineare Suche ist nichts anderes, als die verkettete Liste zu durchlaufen. Bitte lesen Sie mehr darüber und versuchen Sie es zu implementieren. –
Ich würde empfehlen, Standardcontainer zu verwenden. Vektor oder Liste. Dann wirst du eine Funktion finden, die du benutzen kannst. –
Stimmen Sie mit Paul überein. Erlernen Sie zunächst die Grundlagen der (C++) Programmierung mit den vordefinierten Datenstrukturen. Sie müssen Zeiger auf _implement_Datastructures selbst lernen, aber Sie sollten bereits in der _use_ der Datenstrukturen zu diesem Zeitpunkt geübt sein. – MSalters