Форум программистов, компьютерный форум CyberForum.ru

Странные значения. В чем ошибка? - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Проверьте пожалуйста, что не так? http://www.cyberforum.ru/cpp-beginners/thread1033480.html
условие задачи: написать и протестировать функцию, которая находит сумму всех цифр введенного целого числа, если оно является простым и произведение цифр в обратном случае. Так вот когда я делаю функцию, почему-то не правильно определяется число (простое оно или нет) #include <stdio.h> #include <conio.h> int fun(int n) {int d=2, r, sum=0, pr=1; // r - остаток от деления d-делитель...
C++ Коды стрелочек на клавиатуре Не могу понять почему на Esc(27) реагирует, а на стрелку(39) нет. Вот код. Может я что не так делаю? #include <iostream> #include <windows.h> #include <conio.h> using namespace std; HANDLE hConsole, hStdOut = GetStdHandle(STD_OUTPUT_HANDLE); enum ConsoleColor { http://www.cyberforum.ru/cpp-beginners/thread1033473.html
Задача на добавление строки в массив C++
Вставить новую строку после всех строк, в которых нет ни одного четного эле* мента. Добавлено через 36 секунд Помогите, кому неслишком сложно. Все задачи могу делать на массивы, кроме вставления строк.
список C++
программа на С++ должна обеспечивать интерактивный режим просмотра элементов списка. Как это осуществит,кто знает?
C++ интерактивный доступ к элементам списка в С++ http://www.cyberforum.ru/cpp-beginners/thread1033460.html
программа должна обеспечивать интерактивный режим просмотра элементов списка. Как это осуществит,кто знает?
C++ Описать функцию PoslSu(t), которая выводит на печать последнюю строку непустого текстового файла Описать функцию PoslSu(t), которая выводит на печать последнюю строку непустого текстового файла t (t-файловая переменная). Каким образом можно реализовать, напишите пожалуйста или алгоритм, или код. Спасибо. подробнее

Показать сообщение отдельно
Ярославна
0 / 0 / 0
Регистрация: 07.02.2012
Сообщений: 10
08.12.2013, 19:09     Странные значения. В чем ошибка?
Получаются странные значения:
max и min элементы получаются вне диапазона. ПОчему?

Используя генератор случайных чисел, заполнить массив из 20 элементов целочисленными значениями в диапазоне [11, 39], сумма цифр которых меньше 7.
Прототип пользовательской функции:
int genprint(int*, const int, const int, const int);
параметры функции: массив, число элементов массива, левая и правая границы интервала случайных чисел, верхняя граница суммы чисел. Функция возвращает общее число сгенерированных значений, которое потребовалось для заполнения всего массива числами.
Вычислить сумму элементов массива, расположенных между вторым минимальным и вторым максимальным элементами.
ПРототип пользовательской функции:
int sum2mxn(int*, const int, int&, int&);
параметры функции: массив, число элементов масива, (вторые) максимальный и минимальный элементы(ссылки).
Функция возвращает сумму элементов массива, расположенных между вторым минимальным и вторым максимальным элементами.
#include "stdafx.h"
#include <iostream>
#include <iomanip>
#include <ctime>
#include <cstdlib>

using namespace std;
#define N 10

int genprint(int *A, const int arrSize, const int left, const int right, const int high)
{
int a;
int i = 0, counter = 0;
while(i<N)
{
a=rand()%(right-left+1)+left;
counter ++;
if((a%10)+(a/10)<7)
{
A[i] = a;
i++;
}
}
return counter;
}

int find2min(int* pn, int& index)
{
int B[N] = { 0 };
int count = 2, n = 0;
while (--count >= 0)
{
int min = 0;
for (int i = 0; i < N; i++)
if (pn[i] < pn[min])
{
bool found = false;
for (int k = n-1; k >= 0 && !found; k--)
found = (B[k] == i) ? 1 : 0;

if (found == false)
min = i;
}

if (min >= 0) B[n++] = min;
}

if (index >= 0) index = B[1];
return index;
}

int find2max(int* pn, int& index)
{
int B[N] = { 0 };
int count = 2, n = 0;
while (--count >= 0)
{
int max = 0;
for (int i = 0; i < N; i++)
if (pn[i] > pn[max] || max == 0)
{
bool found = false;
for (int k = n-1; k >= 0 && !found; k--)
found = (B[k] == i) ? 1 : 0;

if (found == false)
max = i;
}

if (max >= 0) B[n++] = max;
}

if (index >= 0) index = B[1];
return index;
}

int sum2mxn(int* pn, int min_i, int max_i)
{
int l = 0, h = 0;
if (min_i > max_i)
{
l = max_i;
h = min_i;
}

else if (min_i < max_i)
{
l = min_i;
h = max_i;
}

else if (min_i == max_i)
return pn[min_i];

int sum = 0;
printf("Сгенерированные значения: ");
for (int i = l+1; i < h; i++)
{
printf("%d ",pn[i]);
sum+=pn[i];
}

printf("\n");

return sum;
}

int main()
{
setlocale(LC_ALL, "Russian");
srand(time(0));

const int arrSize = 20;
int A[arrSize];
int left = 11, right = 39, high = 7;
int chislo;
chislo = genprint(A, arrSize, left, right, high);

int min_i = 0, max_i = 0;
find2min(A, min_i);
find2max(A, max_i);
int max, min;
max=find2max(A, max_i);
min=find2min(A, min_i);

for (int i = 0; i < N; i++)
printf("%d ",A[i]);

printf("\n");
printf("-второй max элемент массива = %d\n", max);
printf("-второй min элемент массива = %d\n", min);
printf("Сумма элементов массива = %d\n", sum2mxn(A, min_i, max_i));

system("pause");
return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 22:29. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru