If the request could not be correctly parsed (including the request entity/body) the appropriate response is 400 Bad Request .
RFC 4918 states that 422 Unprocessable Entity is applicable when the request entity is syntactically well-formed, but semantically erroneous. So if the request entity is garbled (like a bad email format) use 400; but if it just doesn't make sense (like
@example.com) use 422.
If the issue is that, as stated in the question, user name/email already exists, you could use 409 Conflict  with a description of the conflict, and a hint about how to fix it (in this case, "pick a different user name/email"). However in the spec as written, 403 Forbidden  can also be used in this case, arguments about HTTP Authorization notwithstanding.
412 Precondition Failed  is used when a precondition request header (e.g.
If-Match) that was supplied by the client evaluates to false. That is, the client requested something and supplied preconditions, knowing full well that those preconditions might fail. 412 should never be sprung on the client out of the blue, and shouldn't be related to the request entity per se.