По разделам

 

Решение задачи String 69


Дана строка, содержащая латинские буквы и круглые скобки. Если скобки расставлены правильно (то есть каждой открывающей соответствует одна закрывающая), то вывести число 0. В противном случае вывести или номер позиции, в которой расположена первая ошибочная закрывающая скобка, или, если закрывающих скобок не хватает, число −1.

Код (C/C++)

#include <bits/stdc++.h>

using namespace std;

int main()
{
    string  s,  a = "";
    cin >> s;
    for(int i = 0; i < s.size(); ++i){
        if(s[i] == '(')
            a += s[i];
        else if(s[i] == ')'){
            if(a[a.size() - 1] == '(')
                a.erase(a.size() - 1);
            else{
                cout << i;
                return 0;
            }
        }
    }
    if(a.size())
        cout << -1;
    else
        cout << 0;
    return 0;
}

Код (Pascal)

program String69;
var
 S:String;
 i,Num,Error:integer;
 
begin
  Write('S: ');
  Readln(S);
 
  i:=1;
  error:=0;
  while (i<=Length(S)) do
   begin
    if S[i]='(' then Num:=Num+1;
    if S[i]=')' then Num:=Num-1;
    if (Num<0) and (error=0) then error:=i;
    inc(i);
   end;
 
  if error<>0 then Writeln(error)
   else if Num>0 then Writeln(-1)
    else Writeln(0);
end.
									




String. Абрамян
String 1 Просмотров: 6201
String 2 Просмотров: 4361
String 3 Просмотров: 2681
String 4 Просмотров: 3713
String 5 Просмотров: 4360
String 6 Просмотров: 4159
String 7 Просмотров: 2887
String 8 Просмотров: 3604
String 9 Просмотров: 2960
String 10 Просмотров: 3153
String 11 Просмотров: 3821
String 12 Просмотров: 3347
String 13 Просмотров: 4011
String 14 Просмотров: 2941
String 15 Просмотров: 3650
String 16 Просмотров: 3596
String 17 Просмотров: 2945
String 18 Просмотров: 2626
String 19 Просмотров: 3604
String 20 Просмотров: 2750
String 21 Просмотров: 2442
String 22 Просмотров: 2615
String 23 Просмотров: 3634
String 24 Просмотров: 2714
String 25 Просмотров: 1982
String 26 Просмотров: 3197
String 27 Просмотров: 2831
String 28 Просмотров: 2985
String 29 Просмотров: 3725
String 30 Просмотров: 2494
String 31 Просмотров: 2906
String 32 Просмотров: 2350
String 33 Просмотров: 2024
String 34 Просмотров: 1980
String 35 Просмотров: 1852
String 36 Просмотров: 1676
String 37 Просмотров: 1430
String 38 Просмотров: 1565
String 39 Просмотров: 1664
String 40 Просмотров: 1938
String 41 Просмотров: 1725
String 42 Просмотров: 3369
String 43 Просмотров: 1650
String 44 Просмотров: 1620
String 45 Просмотров: 2034
String 46 Просмотров: 1357
String 47 Просмотров: 1270
String 48 Просмотров: 1800
String 49 Просмотров: 1529
String 50 Просмотров: 1572
String 51 Просмотров: 1465
String 52 Просмотров: 1427
String 53 Просмотров: 1389
String 54 Просмотров: 1055
String 55 Просмотров: 1199
String 56 Просмотров: 1022
String 57 Просмотров: 1642
String 58 Просмотров: 1741
String 59 Просмотров: 1534
String 60 Просмотров: 1401
String 61 Просмотров: 1196
String 62 Просмотров: 1256
String 63 Просмотров: 1609
String 64 Просмотров: 1471
String 65 Просмотров: 1345
String 66 Просмотров: 1474
String 67 Просмотров: 1142
String 68 Просмотров: 1392
String 69 Просмотров: 1260
String 70 Просмотров: 1968

Комментарии

Чтобы написать комментарии вам нужно войти в систему или зарегистрироваться



Заявка на расчет