Самый длинный путь в БТС, как сделать диаметр - PullRequest
0 голосов
/ 16 мая 2018

Я уже задавал вопрос по этому поводу, но я продвинулся.поэтому я пытаюсь реализовать в MIPS диаметр дерева.

Благодаря Петеру Кордесу, который помог мне разобраться в некоторых вещах в моем предыдущем вопросе об этом .Итак, я уже реализовал высоту дерева:

.data
tree: .word a
a: .word 5, bb, c
bb: .word 2, d, e 
c: .word 1, 0, 0
d: .word 5, f, g
e: .word 9, 0, h
f: .word 0, 0, 0
g: .word 6, i, 0
h: .word 55, 0, jj
i: .word 4, 0, 0
jj: .word 8, 0, 0 
.text
main: 
la $a0, tree
lw $a0,0($a0)
jal heightOfTree
move $a0, $v0 
li $v0, 1 # Print the return value
syscall
li $v0, 10
syscall
heightOfTree:
bnez $a0, Recursion
li $v0, 0 # Base case
jr $ra
Recursion: #Recursive call height of tree = max (height(leftchild),(height(rightchild)) + 1
addiu $sp, $sp, -12 
sw $ra, 0($sp)
sw $a0, 4($sp)
lw $a0, 4($a0) # height(rightchild)
jal heightOfTree
sw $v0, 8($sp) # Saving the height of the left child
lw $a0, 4($sp) # Taking the Address of the root
lw $a0, 8($a0) # height of right child
jal heightOfTree
lw $t0, 8($sp) # In $t0 the height of the left child ,In $v0 of the right child.
bge $v0, $t0, maximum # Calcolating the max between the left and right (left height - $t0)(right -height - $v0)
move $v0, $t0
maximum: 
addiu $v0, $v0, 1
lw $ra, 0($sp)
addiu $sp, $sp, 12
jr $ra #Returning the height to the main

Это прекрасно работает, но мне не удается вычислить диаметр: (

Я работаю по этому коду

int diameter (node *P)
{
if (p==NULL)
    return 0;
int lheight = height(P->left);
int rheight = height(P->right);
int ldiameter = diameter(p->left);
int rdiameter = diameter(p->right);
int longestpath = max (lheight+rheight+1,max(ldiameter,rdiameter)

return longestpath

диаметр должен быть 7

...