二重リンクリストに問題があるので、2つの質問があります。
まず、説明。
私はstruct
この方法で1つ作成しました:
typedef struct team{
char *name;
char *teamPlace;
}Team;
そして、この方法で私のリストを作成しました:
typedef struct nodeTeam{
int numberOfTeams;
Team team;
struct nodeTeam *next;
struct nodeTeam *prev;
}NodeTeam;
したがって、私のリストにはとが含まれhead
ますtail
。Team
リストにいくつか追加すると、リストhead
int numberOfTeams;
のチーム数が表示されます。tail
リストの最後の要素が含まれ、int numberOfTeams;
その後にIDhead
が含まれます。Team
私のリストは次のように作成されます。
int createsListOfTeams(NodeTeam **head, NodeTeam **tail);
int addNodeTeamsSorted(NodeTeam *head, NodeTeam **tail, Team team);
void printListOfTeams(NodeTeam *listofTeams);
int main()
{
NodeTeam *headTeams,*tailTeams;
Team eq;
/*Creates the doubly linked list*/
if(createsListOfTeams(&headTeams,&tailTeams)){ /*See below this part of the code*/
printf("\nError\n");
return 0;
}
/*Teams are on a .txt file. The code for reading from a file is missing. It´s working ok so I believe it's not needed.
After reading one line after another it will do this
addNodeEquipasSorted(headTeams,tailTeams,eq);
where eq is a `struct` with the team data.
*/
/*Will print all the teams*/
printListOfTeams(headTeams);
return 0;
}
これは、リストを作成するためのコードです。
/*Add the teams to the doubly linked list. At the end, all teams will be sorted by name*/
int createsListOfTeams(NodeTeam **head, NodeTeam **tail){
(*head) = (NodeTeam *)malloc(sizeof(NodeTeam));
if ((*head) == NULL){
return -1;
}
(*head)->numberOfTeams = 0;
strcpy((*head)->team.teamPlace,"");
strcpy((*head)->team.name,"");
(*head)->next = NULL;
(*head)->prev = NULL;
*tail = *head;
return 0;
}
Team
私のリストに(チーム名でソートされた)aを追加するためのコードは次のとおりです。
/*Creates the doubly linked list*/
int addNodeTeamsSorted(NodeTeam *head, NodeTeam **tail, Team team){
NodeTeam *no, *aux;
/*Memory alloc for a new node*/
no = (NodeTeam*) malloc(sizeof(NodeTeam));
if (no == NULL){
return -1;
}
/*Updates the number of element of the list*/
head->numberOfTeams++;
/*Creates a copy of tail*/
aux = (*tail);
/*Puts team data on node*/
no->team = team;
/*to see if the list it's empty(no it's the first element of my list) or the last node as a name "smaler" then node*/
if(head == *tail || strcmp((*tail)->team.name,no->team.name) <= 0)
{
if (head == *tail){
no->numberOfTeams = 1;
}
else{
no->numberOfTeams = head->numberOfTeams;
(*tail)->numberOfTeams = no->numberOfTeams - 1;
}
no->next = (*tail)->next;
no->prev = *tail;
(no->prev)->next = no;
(*tail) = no;
aux = (*tail);
}
else{ /*If not the first element*/
head = head->next; /*To advance to the first item after my head*/
while(strcmp(head->team.name,no->team.name) < 0 && strcmp((*tail)->team.name,no->team.name) > 0 && head != *(tail)){
head = head->next;
(*tail) = (*tail)->prev;
}
if(strcmp(head->team.name,no->team.name) >= 0){
no->next = head;
no->prev = head->prev;
head->prev = no;
(no->prev)->next = no;
no->numberOfTeams = (no->next)->numberOfTeams;
(no->next)->numberOfTeams = no->numberOfTeams + 1;
if((no->prev)->prev != NULL){
(no->prev)->numberOfTeams = no->numberOfTeams - 1;
}
}
else{
no->next = (*tail)->next;
no->prev = (*tail);
no->numberOfTeams = (no->prev)->numberOfTeams + 1;
(no->prev)->next = no;
(no->next)->prev = no;
}
}
/*Puts `tail` pointing to the right position*/
if (aux != (*tail)){
(*tail) = aux;
}
return 0;
}
私の.txtファイルには、次のデータがあります。
E team;E team place
J team;J team place
G team;G team place
F team;F team place
L team;L team place
A team;A team place
H team;H team place
O team;O team place
K team;K team place
P team;P team place
N team;N team place
B team;B team place
C team;C team place
M team;M team place
D team;D team place
I team;I team place
そしてこれが出力です。
---------------------------------------------------------
| List of Teams |
---------------------------------------------------------
| Number of Teams | 16 | no 00740ff0 | prev 00000000 | next 00741240 |
--------------------------------------------------------
| ID | Team Name | Team Place |
--------------------------------------------------------
| 1 | A team | A team place | no 00741240 | prev 00740ff0 | next 00741450 |
| 2 | B team | B team place | no 00741450 | prev 00741240 | next 007436b0 |
| 3 | C team | C team place | no 007436b0 | prev 00741450 | next 00743760 |
| 4 | D team | D team place | no 00743760 | prev 007436b0 | next 00741088 |
| 5 | E team | E team place | no 00741088 | prev 00743760 | next 00741190 |
| 2 | F team | F team place | no 00741190 | prev 00741088 | next 00741138 |
| 3 | G team | G team place | no 00741138 | prev 00741190 | next 00741298 |
| 4 | H team | H team place | no 00741298 | prev 00741138 | next 007437b8 |
| 5 | I team | I team place | no 007437b8 | prev 00741298 | next 007410e0 |
| 4 | J team | J team place | no 007410e0 | prev 007437b8 | next 00741348 |
| 5 | K team | K team place | no 00741348 | prev 007410e0 | next 007411e8 |
| 7 | L team | L team place | no 007411e8 | prev 00741348 | next 00743708 |
| 8 | M team | M team place | no 00743708 | prev 007411e8 | next 007413f8 |
| 8 | N team | N team place | no 007413f8 | prev 00743708 | next 007412f0 |
| 9 | O team | O team place | no 007412f0 | prev 007413f8 | next 007413a0 |
| 10 | P team | P team place | no 007413a0 | prev 007412f0 | next 00000000 |
--------------------------------------------------------
この出力を使用すると、チームが名前でソートされてリストに追加されていることがわかります。私がメモリアドレスを出力するために作成したデバグは、すべてが正常であることを示しています。問題はチームIDにあります。これはint numberOfTeams;
それで、最後にこのテキストのすべての後、これらは私の質問です:
質問1チームIDを解決するにはどうすればよいですか。つまり、Team
リストに新しいIDを挿入した後、IDが正しいIDに更新されます。
質問2私addNodeTeamsSorted
はIDの例外に取り組んでいますが、それは「途切れ途切れ」であると信じています。いくつかの最適化をお勧めできますか?
ありがとう