Создайте графику и используйте связанный список

Я должен сделать 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;
}
Другие вопросы по тегам