Quando coloco para fazer primeiro as multiplicações, preferencia o eclipse acusa erros, o que estou fazendo de errado???Está faltando casas decimais no float, o que fazer???
Copia e cola o erro que você está obtendo. Acredito que seja necessário acrescentar um cast para converter o valor da sua equação para a variável float que você quer.
O cast ficaria assim:
valor = (float) (equação);
Observe que a depender do tipo (double, int ou float) de dado que você utiliza você irá obter resultados diferentes. Acho que isso deve estar acontecendo com você.
[code]float valor;
valor = 150/100; // valor = 1,0
valor = (float) 150/100; //valor = 1,5
[/code]
Em operações entre dois inteiros, o resultado será um inteiro. Logo 150/100 irá retornar 1 já que o 0,5 não faz parte dos inteiros. O seu resultado será aproximado e armazenado na variável float como 1.0. Daí a divergência do que você está esperando.
A partir do momento que um dos números se torna float (no meu exemplo o 150), o resultado da operação matemática será do operando que tem maior precisão, ou seja, o seu resultado será em float e irá retornar 1,5.
Uma curiosidade: por que vc não resolve as operações com os números em vez de pô-los na equação? Por que põe 1x10/100 em vez de escrever simplesmente 0.1? Já que esses números são conhecidos e constantes, fazer o programa calcular essas operações não tem sentido (na minha visão).
Em relação a variável valor, vc a tipificou como? Int, float, double etc? Neste trecho do código que pôs está faltando essa informação. Se for local, basta fazer float valor = (…), como você já sabe.
Em relação as equações, rever como foi sugerido. Mas, assim mesmo, se não me engano, na equação do erro falta um parêntesis no meio da equação, não no fim.
Seria mais fácil entender o que acontece se vc mostrasse a mensagem de erro. Geralmente ela diz o que fazer, tanto no Eclipse como no NetBeans (se bem que às vezes não dá para entender o que ele quer que façamos…hahahahaha).