Молот Шотландцев
Высший разум
(301469)
3 года назад
Это называется синтаксический анализ строки или парсинг строки. И сразу скажу что это довольно сложное занятие. Поскольку для вычисления строки как математического выражения нужно учитывать приоритеты операций (умножение и деление выше сложения и вычитания). Плюс нужно учитывать отрицательные числа и числа с десятичной точкой. На Питоне я это даже не пытался делать. Но сделал на Javascript. Получилась вот такая длинная функция. И это еще без возможности вводить и учитывать скобки, со скобками код был бы совсем устрашающим
>>>
var a = prompt();
function solve(arg) {
let s = arg;
// разделяем на числа и знаки
let ss = s.split('');
let st1 = [];
for (var i = 0; i < ss.length - 1; i++) {
if ((!isNaN(ss[i]) && (isNaN(ss[i + 1]) && ss[i + 1] != '.')) || ((isNaN(ss[i]) && ss[i] != '.' ) && !isNaN(ss[i + 1]))) {
ss.splice(i + 1,0,' ');
i++;
//console.log(ss[i])
}
}
sss = ss.join('').split(' ');
//отрицательные числа
if (sss[0] == '-') {
let changeFirstABS = -sss[1];
sss[1] = changeFirstABS;
sss.splice(0,1);
}
for (var i = 0; i < sss.length; i++) {
if(sss[i].length >= 2 && isNaN(sss[i])) {
if (sss[i].charAt(1) == '-') {
console.log(-sss[i+1]);
let changeABS = -sss[i+1];
sss[i+1] = changeABS;
}
let t = sss[i].substring(0,1);
sss[i] = t;
}
}
//отрицательные числа
for (var i = 0; i < sss.length; i++) {
if (!isNaN(sss[i]) || sss[i] == '+' || sss[i] == '-') { st1.push(sss[i]) }
else {
console.log(st1);
// умножение
if (sss[i] == '*') {
console.log(' mult ', st1, sss[i - 1], sss[i + 1]);
res = sss[i - 1] * sss[i + 1];
i++;
//console.log('before',st1);
//console.log(st1[st1.length - 1]);
st1[st1.length - 1] = res;
//console.log('after',st1);
}
// деление
if (sss[i] == '/') {
res = sss[i - 1] / sss[i + 1];
i++;
st1[st1.length - 1] = res;
}
}
}
console.log('st1:',st1);
// подсчитываем результат
res = +st1[0];
console.log('first',res);
for (var i = 0; i < st1.length; i++) {
if (st1[i] == '+') {
console.log(true, st1[i + 1]);
res += +st1[i + 1];
console.log('res', res);
}
if (st1[i] == '-') {
res -= +st1[i + 1];
}
}
return res;
}
alert(solve(a));
ivan866_zПросветленный (20377)
3 года назад
полный ответ, но в данном случае дано конкретное выражение без скобок
их просто проверяют как они пользуются list comprehension и индексами