En C, ¿es posible usar la recursión dentro de la función sprintf? Por alguna razón, me sale un error de segmentación cuando lo hago:C: sprintf y recursión
inline char *TreeNode_toString(const TreeNode *node)
{
char *out;
if(TreeNode_isExternal(node)) // If the node has no children...
{
sprintf(out, "%s:%.2f", node->name, node->distance);
}
else // The node is strictly binary, so it will have two non-null children
{
char *l = TreeNode_toString(node->l); // l = left child
char *r = TreeNode_toString(node->r); // r = right child
sprintf(out, "(%s,%s):%.2f", l, r, node->distance);
}
return out;
}
Quiere decir asignado no inicializado - el valor de declarar de fuera no importa solo un poco de espacio de memoria – Mark