Azzera filtri
Azzera filtri

fprintf curiosity about incorrect value returned when string is assigned as a number.

1 visualizzazione (ultimi 30 giorni)
Hello,
I am learning about fprintf and I was playing around. I ended up with this string below. I realize now that in the second sentence it should be %s because it's printing a string.
But! Here's my question. I don't get returned an error message. Instead, I get that 10 + 34 is 52.
WHY? I want to know.
N = 10; S = 34;
fprintf('What is %g plus %g? It''s %g! \n', N , S, num2str(N + S))
When I use fprintf('What is %g plus %g? It''s %s! \n', N , S, num2str(N + S)) I get 44 as expected.
Can anyone tell me why 52 is the number returned when the string is commanded as a number?

Risposta accettata

Walter Roberson
Walter Roberson il 26 Ott 2022
the sum is 44 and num2str(44) is '44' which is a character vector.
Every character is encoded as a 16 bit number, so the character vector '44' is encoded as pair of 16 bit numbers. The encoding for the digits 0 to 9 is integer 48 plus the digit value, so digit 4, '4' is encoded as 48+4 = 52. So you are passing in a vector of two values each of which happens to be 52 numerically, and the %g format would display the 52
If you looked closely you probably got an extra line
What is 52 plus
where it went to display the second '4'

Più risposte (0)

Categorie

Scopri di più su Interactive Control and Callbacks in Help Center e File Exchange

Tag

Prodotti


Release

R2022a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by