Создайте графику и используйте связанный список
Я должен сделать 2 кода, которые строят графику. У меня уже 1. Это просто строительная картинка:
double a = LabeledEdit1 -> Text.ToDouble();
double S = LabeledEdit2 -> Text.ToDouble();
Series1-> Clear();
for( float i = -5; i <= 5; i+=S ) {
float y = exp(i*log(a));
Series1->AddXY( i , y ,"",clBlue);
}
Но вторая задача для меня намного сложнее. Я должен сделать новую структуру
struct K {
double x;
double y;
struct K *next;
};
а затем сделать связанный список. Затем поместите точки (x,y) в StringGrid и затем создайте график. Я сделал несколько кусков кода, но он не работает правильно. Нужна помощь.
K* head = 0;
K* curr = 0;
K* vyv;
double x = 1;
double y;
double a = LabeledEdit1 -> Text.ToDouble();
double S = LabeledEdit2 -> Text.ToDouble();
int i=0;
for (i = 0; i < 500; ++i) {
if (i==0) {
y = exp(x*log(a));
head = (K*) malloc(sizeof K);
head->x = x;
head->y = y;
head->next = NULL;
}
else {
y = exp(x*log(a));
curr = (K*) malloc(sizeof K);
curr->x = x;
curr->y = y;
curr->next = NULL;
}
x++;
}
vyv = head;
i = 0;
int l = 0, I = 0;
while(vyv){
x = vyv->x;
StringGrid1->Cells[i][0] = x;
y = vyv->y;
StringGrid1->Cells[i][1] = y;
Series1->AddXY( i , y ,"",clBlue);
vyv = vyv->next;
++i;
}
1 ответ
Ваш первый цикл не связывает узлы вместе, поэтому все они имеют next
ценность NULL
Таким образом, ваш второй цикл выполняет только 1 итерацию (для head
узел).
И вы также должны использовать new
вместо malloc()
,
Попробуйте это вместо этого:
K* head = 0;
K* curr = 0;
K* last = 0;
double x = 1;
double y;
double a = LabeledEdit1 -> Text.ToDouble();
double S = LabeledEdit2 -> Text.ToDouble();
int i;
for (i = 0; i < 500; ++i) {
y = exp(x*log(a));
curr = new K;
curr->x = x;
curr->y = y;
curr->next = NULL;
if (!head) head = curr;
if (last) last->next = curr;
last = curr;
x++;
}
curr = head;
i = 0;
int l = 0, I = 0;
while(curr){
x = curr->x;
StringGrid1->Cells[i][0] = x;
y = curr->y;
StringGrid1->Cells[i][1] = y;
Series1->AddXY( i , y ,"",clBlue);
curr = curr->next;
++i;
}
И не забудьте освободить узлы, когда вы закончите, используя их:
curr = head;
while(curr){
K *next = curr->next;
//...
delete curr;
curr = next;
}
С учетом сказанного, вы должны использовать std::list
вместо этого, пусть он обрабатывает управление памятью для вас:
#include <list>
struct K {
double x;
double y;
};
std::list<K> myList;
double x = 1;
double y;
double a = LabeledEdit1 -> Text.ToDouble();
double S = LabeledEdit2 -> Text.ToDouble();
int i;
for (i = 0; i < 500; ++i) {
y = exp(x*log(a));
K curr;
curr.x = x;
curr.y = y;
myList.push_back(curr);
x++;
}
i = 0;
int l = 0, I = 0;
for(std::list<K>::iterator iter = myList.begin(); iter != myList.end(); ++iter)
{
x = iter->x;
StringGrid1->Cells[i][0] = x;
y = iter->y;
StringGrid1->Cells[i][1] = y;
Series1->AddXY( i , y ,"",clBlue);
++i;
}