Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
Консультант Витте
 Аватар для DmitryM5
106 / 86 / 45
Регистрация: 27.08.2013
Сообщений: 1,356
Записей в блоге: 1

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

03.10.2013, 19:33. Показов 884. Ответов 6
Метки нет (Все метки)

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

1.test1.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
#ifndef TEST1_H
#define TEST1_H
bool PowK(int a,int K) ;
int FindFirstPowK(int K);
double Garmon(double eps );
int Raznost(int N);
void PrintArray(const double *a,int N);
double Array(double *a,int N);
void swapmy(int &a,int &b);
void Array2(int *a,int N);
void PrintArray2(const int *a,int N);
#endif TEST1_H
2.test1.cpp
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#include <iostream>
#include <locale>
#include "test1.h"
 
using namespace std;
 
 
bool PowK(int a,int K) {
    int b=K;
    if (a==1) return true;
    while(K<=a) {
        if (K==a) return true;
        K*=b;;
        
    }
    return false;
}
 
int FindFirstPowK(int K) {
    int a=1;
    while(a!=0) {
        cin>>a;
        if (PowK(a,K))
            return a;
    }
    return 0;
}
 
double Garmon(double eps ) {
    double Sum=1;
    double a=1;
    int N=1;
    while (abs(a)>eps) {
        N++;
        a=1.0/N;
        Sum+=a;
    }
    return Sum;
}
 
int Raznost(int N) {
    int a;
    int max=-99999999,min=9999999999;
    for (int i=1;i<=N;i++) {
        cin>>a;
    if (a<min) min=a;
    if (a>max) max=a;
    }
    return abs(max-min);
}
 
void PrintArray(const double *a,int N) {
    for (int i=0;i<N;i++)
        cout<<a[i]<<" ";
    cout<<endl;
}
double Array(double *a,int N) {
    double Sum=0;
    double Fact=1;
    a[0]=1;
    Sum+=a[0];
    for (int i=1;i<N;i++) {
        Fact*=(i+1);
        a[i]=1/Fact;
        Sum+=a[i];
    }
    return Sum;
}
 
void swapmy(int &a,int &b) {
    int h=a;
    a=b;
    b=h;
}
void PrintArray2(const int *a,int N) {
    for (int i=0;i<N;i++)
        cout<<a[i]<<" ";
    cout<<endl;
}
 
void Array2(int *a,int N) {
    for (int i=0;i<N-1;i+=2) {
        swapmy(a[i],a[i+1]);
    }
 
}
3.main.cpp

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
34
35
36
37
38
39
40
41
42
43
#include <iostream>
#include <locale>
#include "test1.h"
 
using namespace std;
 
 
int main(){
    const int N1=10;
    int K,N;
    double eps;
    std::locale::global(std::locale(""));
 
    /*1.Дано целое число K и набор ненулевых целых чисел; признак его завершения — число 0. 
    Вычислить номер первого числа в наборе, являющегося степенью числа K. Если такого числа нет, то вернуть ноль. **/
    cout<<"Введите целое число K "<<endl;
    cin>>K;
    cout<<"Введите набор ненулевых целых чисел,заканчивая нулем "<<endl;
    cout<<"Номер первого числа в наборе,являющегося степенью числа K = "<<FindFirstPowK(K)<<endl;
    /*2.Вычислить сумму гармонического ряда 1+1/2+...+1/N с заданной точностью.*/
    cout<<"Введите заданную точность (eps>0) "<<endl;
    cin>>eps;
    cout<<"Сумма гармонического ряда = "<<Garmon(eps )<<endl;
    /*3.Дано целое число N и набор из N целых чисел. Найти разность, взятую по модулю между максимальным и минимальным элементами набора.*/
    cout<<"Введите целое число N "<<endl;
    cin>>N;
    cout<<"Введите набор из N целых чисел "<<endl;
    cout<<""<<Raznost(N)<<endl;
    cout<<endl;
    /*4.Дан целочисленный массив размера N, заполнить его первыми членами последовательности 1/n!. Найти сумму элементов массива.*/
    double a[N1];
    cout<<"Сумма элементов массива = "<<Array(a,N1)<<endl;
    PrintArray(a,N1);
    cout<<endl;
    /*5.Дан массив целых чисел размерности 2N. Переместить его элементы так, чтобы они располагались в массиве в следующем порядке 
    A[2],A[1],A[4],A[3],…,A[2N],A[2N-1].*/
    int b[N1]={1,2,3,4,5,6,7,8,9,10};
    PrintArray2(b,N1);
    Array2(b,N1);
    PrintArray2(b,N1);
    system("pause");
    return 0;
}
Добавлено через 41 минуту
update!
1.Какое то значение из 1-го задания попадает в переменную 2-го задания(в eps).Это происходит при вводе набора чисел через пробел...А через enter нормально все.И как-то программа не по условию работает я ввожу набор и если нашел нужное число ,то возвращаю его.Но по сути я не закончил ввод набора,с окончание нуля...
2.Не правильно работает 2-ое задание.Сумма ряда неверная вроде бы.
Просьба помочь))
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.10.2013, 19:33
Ответы с готовыми решениями:

Найти ошибки в коде и исправить эти ошибки (Наследование)
Вот в общем 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 ...

6
Модератор
Эксперт С++
 Аватар для zss
13769 / 10962 / 6491
Регистрация: 18.12.2011
Сообщений: 29,237
03.10.2013, 20:07
1. Остаток введенной ранее строки перед вводом новой надо дочитать до конца.
2. Гармонический ряд расходится. Поэтому надо суммировать конечное число членов,
а не до того как 1./N станет меньше eps.
1
Консультант Витте
 Аватар для DmitryM5
106 / 86 / 45
Регистрация: 27.08.2013
Сообщений: 1,356
Записей в блоге: 1
03.10.2013, 20:34  [ТС]
Цитата Сообщение от zss Посмотреть сообщение
1. Остаток введенной ранее строки перед вводом новой надо дочитать до конца.
2. Гармонический ряд расходится. Поэтому надо суммировать конечное число членов,
а не до того как 1./N станет меньше eps.
1. Не совсем понял я,как исправить???И повтор вопроса:Это происходит при вводе набора чисел через пробел...А через enter нормально все.И как-то программа не по условию работает я ввожу набор и если нашел нужное число ,то возвращаю его.Но по сути я не закончил ввод набора,с окончание нуля...
2.Ну теоретически можно же так вычислить как у меня?Ведь найдется член последовательности 1/N<eps?И цикл суммирования закончится.Чем больше eps,тем больше операций выполнится(как будто я ввел N=10000 etc).?
Может Задание не корректно поставлено???Ведь если я буду подавать N,то eps потеряет смысл?
0
Модератор
Эксперт С++
 Аватар для zss
13769 / 10962 / 6491
Регистрация: 18.12.2011
Сообщений: 29,237
03.10.2013, 21:38
1. Чтобы не парится организуйте диалог для ввода каждого числа:
C++
1
2
3
4
5
6
7
8
9
10
int FindFirstPowK(int K) {
    int a=1;
    while(a!=0) 
    {
         cout<<"Введите очередное число, 0 - конец ввода:";
        cin>>a;
        if (PowK(a,K))
            return a;
    }
    return 0;
2. От значения eps будет сильно зависеть результат. Поэтому он бессмысленный.
Функция должна вычислять сумму n членов.
1
Консультант Витте
 Аватар для DmitryM5
106 / 86 / 45
Регистрация: 27.08.2013
Сообщений: 1,356
Записей в блоге: 1
04.10.2013, 11:04  [ТС]
Цитата Сообщение от zss Посмотреть сообщение
1. Чтобы не парится организуйте диалог для ввода каждого числа:
C++
1
2
3
4
5
6
7
8
9
10
int FindFirstPowK(int K) {
    int a=1;
    while(a!=0) 
    {
         cout<<"Введите очередное число, 0 - конец ввода:";
        cin>>a;
        if (PowK(a,K))
            return a;
    }
    return 0;
2. От значения eps будет сильно зависеть результат. Поэтому он бессмысленный.
Функция должна вычислять сумму n членов.
Спасибо,но все таки не разобрался я почему с 1 заданием так происходит и сама формулировка 2-го задания...

Добавлено через 12 часов 47 минут
Если кто может конкретно объясните.
0
Модератор
Эксперт С++
 Аватар для zss
13769 / 10962 / 6491
Регистрация: 18.12.2011
Сообщений: 29,237
04.10.2013, 12:05
1. Потоковый ввод осуществляется через специальный буфер.
Поэтому а. данные не сразу попадают на обработчик. б. часть буфера,
которая не была принята одним оператором ввода, попадает на следующий.
2. Формулировка должна быть такая
"Вычислить сумму первых n членов гармонической последовательности"
1
Консультант Витте
 Аватар для DmitryM5
106 / 86 / 45
Регистрация: 27.08.2013
Сообщений: 1,356
Записей в блоге: 1
04.10.2013, 17:00  [ТС]
Цитата Сообщение от zss Посмотреть сообщение
1. Потоковый ввод осуществляется через специальный буфер.
Поэтому а. данные не сразу попадают на обработчик. б. часть буфера,
которая не была принята одним оператором ввода, попадает на следующий.
2. Формулировка должна быть такая
"Вычислить сумму первых n членов гармонической последовательности"
Спасиба!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.10.2013, 17:00
Помогаю со студенческими работами здесь

Исправить ошибки в коде
Помогите исправить ошибки(( #include &lt;fstream&gt; #include &lt;iostream&gt; #include &lt;string.h&gt; #include &lt;cstdio&gt; #include &lt;cstdlib&gt;...

исправить ошибки в коде
Помогите и исправьте ошибки в моём коде. Буду очень благодарен. Ссылка на условие задачи: ...

Исправить ошибки в коде
#include &lt;math.h&gt; #include &lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; int main(int argc, char *argv) { int p; float...

Исправить ошибки в коде
Возникла проблема при написании программы. Выдаются ошибки которых нет на самом деле. помогите, пожалуста. код Parcer::Parcer() { ...

Исправить ошибки в коде
#include &lt;iostream.h&gt; #include &lt;conio.h&gt; #include &lt;string.h&gt; // ------------ -------------------------------- class TStudent { ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru