Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
1 / 1 / 0
Регистрация: 04.11.2012
Сообщений: 50

исправить ошибки в коде

18.11.2012, 17:29. Показов 889. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите и исправьте ошибки в моём коде. Буду очень благодарен. Ссылка на условие задачи:
http://acm.timus.ru/problem.aspx?space=1&num=1880

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#include <iostream>
 
using namespace std;
 
int main()
{
int n, k, l, i, a, b, c, chislo=0;
int *man=new int [100];
int *mak=new int [100];
int *mal=new int [100];
 
cin >> n;
for (i=0; i<=n-1; i++)
  cin >> man[i];
 
cin >> k;
for (i=0; i<=k-1; i++)
 cin >> mak[i];
 
cin >> l;
for (i=0; i<=l-1; i++)
 cin >> mal[i];
 
for (a=0; a<=n-1; a++)
 for (b=0; b<=k-1; b++)
  for (c=0; c<=l-1; c++)
   if (man[a] == mak[b] == mal[c])
    chislo++;
cout << chislo << endl;
 
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.11.2012, 17:29
Ответы с готовыми решениями:

Найти ошибки в коде и исправить эти ошибки (Наследование)
Вот в общем 3 файла, изучаю наследование на примере односвязного и двусвязного списков: list.h (inline) #pragma once class list...

Найти ошибки в коде и исправить эти ошибки
Есть у меня вот такой код: #include &lt;iostream&gt; using namespace std; class A{ private: int* a; size_t size_; ...

Найти ошибки в коде и исправить эти ошибки - C++
Судя по вываливающейся ошибки, идет двойное освобождение памяти. У самого не получается отловить откуда. A.h #pragma once ...

8
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 4
18.11.2012, 18:01
вот рабочий вариант

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include "stdafx.h"
#include <iostream>
 
using namespace std;
 
int main()
{
    int n, k, l, i, a, b, c, chislo=0;
    int *man=new int [100];
    int *mak=new int [100];
    int *mal=new int [100];
 
    cin >> n;
    for (i=0; i<=n-1; i++)
        cin >> man[i];
 
    cin >> k;
    for (i=0; i<=k-1; i++)
        cin >> mak[i];
 
    cin >> l;
    for (i=0; i<=l-1; i++)
        cin >> mal[i];
 
    for (a=0; a<=n-1; a++)
        for (b=0; b<=k-1; b++)
            for (c=0; c<=l-1; c++)
                if (man[a] == mak[b] == mal[c])
                    chislo++;
    cout << chislo << endl;
 
    return 0;
}
0
1 / 1 / 0
Регистрация: 04.11.2012
Сообщений: 50
18.11.2012, 18:21  [ТС]
А в чём вообще отличие? Запустил - выдаёт те же самые неправильные ответы
0
0 / 0 / 0
Регистрация: 18.11.2012
Сообщений: 4
18.11.2012, 18:36
наличие
C++
1
#include "stdafx.h"
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
18.11.2012, 18:55
Цитата Сообщение от Kreative Посмотреть сообщение
наличие Код C++
1 #include "stdafx.h"
это не панацея.
Там компилятор наоборот выдаст ошибку компиляции с такой строкой. Самая главная ошибка, то что под каждую команду выделяется всего 100 чисел, хотя по условию задачи их может быть до 4000.
Поиск лучше вести не тремя вложенными циклами а бинарным поиском (ведь по условию задачи числа расположены в порядке возрастания)
1
1 / 1 / 0
Регистрация: 04.11.2012
Сообщений: 50
18.11.2012, 20:32  [ТС]
valeriikozlov, а без бинарного способа моим способом(вложением циклов)можно решить? Изменил размер динамического массива до 4000, но всё равно программа не проходит даже первый тест. Подскажите, как можно написать программу без бинарного поиска.
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
19.11.2012, 00:08
Цитата Сообщение от лыс Посмотреть сообщение
Подскажите, как можно написать программу без бинарного поиска.
бинарный поиск хорошо, но в данном случае и первый массив упорядочен по возрастанию, поэтому вот этот способ считаю одним из самых оптимальных для этой задачи:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <iostream>
using namespace std;
int main()
{
    int n, k, l, i, a=0, b=0, c=0, chislo=0;
    cin >> n;
    int *man=new int [n];
    for (i=0; i<=n-1; i++)
        cin >> man[i];
    cin >> k;
    int *mak=new int [k];
    for (i=0; i<=k-1; i++)
        cin >> mak[i];
    cin >> l;
    int *mal=new int [l];
    for (i=0; i<=l-1; i++)
        cin >> mal[i]; 
    while(a<n && b<k && c<l)
    {
        while(b<k && mak[b]<man[a])
            b++;
        while(c<l && mal[c]<man[a])
            c++;
        if(b<k && mak[b]==man[a] && c<l && mal[c]==man[a])
            chislo++;
        a++;
    }
    cout << chislo << endl;
 
    return 0;
}
так сказать одновременное движение вперед по всем трем массивам.
1
1 / 1 / 0
Регистрация: 04.11.2012
Сообщений: 50
19.11.2012, 08:38  [ТС]
Спасибо,valeriikozlov, программа прошла все 20 тестов (когда запускал свою выдавало почему-то "обращение по недоступному адресу в памяти" - не знаете, почему?)
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
19.11.2012, 21:15
Цитата Сообщение от лыс Посмотреть сообщение
когда запускал свою выдавало почему-то "обращение по недоступному адресу в памяти" - не знаете, почему?
насчет "обращение по недоступному адресу в памяти" могу только предположить: был выход за пределы массива (лучше покажите код, на который выдавалось такое сообщение, тогда подскажу точно).
У Вас в коде есть еще ошибка - никогда так не пишите:
Цитата Сообщение от Kreative Посмотреть сообщение
C++
1
if (man[a] == mak[b] == mal[c])
правильно так:
C++
1
if (man[a] == mak[b] && man[a] == mal[c])
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.11.2012, 21:15
Помогаю со студенческими работами здесь

Исправить ошибки в коде
Вообщем нужна помощь в нахождении ошибок!5 легеньких Заданий(в комментариях в main.cpp). Суть ошибок: 1.Какое то значение из 1-го...

Исправить ошибки в коде
заранее огромное спасибо:) #include&lt;iostream&gt; #include&lt;stdio.h&gt; #include&lt;conio.h&gt; #include&lt;string.h&gt; #include&lt;math.h&gt; ...

Исправить ошибки в коде
#include &lt;iostream&gt; using namespace std; int main() { int n; int i; int e = 0; int l = 0;

Исправить ошибки в коде
#include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;process.h&gt; #include &lt;fstream&gt; #include &lt;iomanip&gt; class Student { ...

Исправить ошибки в коде
Я тут на писал правильно скажите? #include &quot;stdafx.h&quot; #include &lt;iomanip&gt; #include &lt;iostream&gt; #include &lt;ctime&gt; #include...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru