Технический форум

Технический форум (http://www.tehnari.ru/)
-   C/C++/С# (http://www.tehnari.ru/f42/)
-   -   В векторе найти два элемента, наиболее близкие к среднему арифметическому (http://www.tehnari.ru/f42/t245406/)

ma[r?]ks 04.04.2016 12:54

В векторе найти два элемента, наиболее близкие к среднему арифметическому
 
Подскажите, пожалуйста, как реализовать данную программку без особых заморочек.
Желательно с пояснениями.
Создать процедуру, определяющую в целочисленном векторе vectorn два элемента, наиболее близкие к среднему арифметическому всех элементов вектора. Элементы, расположенные между ними, отсортировать по возрастанию.
Наброски кода есть, но код бредовый.
[C]
#include <conio.h> #include <math.h> #include <stdio.h> #include <time.h> #include <stdlib.h> int function(int n, int *vector); int main() { int i, n, m, vector_max, vector_min, l; time_t t; // Текущее время для инициализации генератора случайных чисел(рандомайзера) srand((unsigned) time(&t)); // Инициализация рандомайзера printf("\nVvedite min znachenie diapazona:"); // Ввод данных scanf("%d", &vector_min); printf("\nVvedite max znachenie diapazona:"); scanf("%d", &vector_max); printf("\nVvedite razmer vectora:"); scanf("%d", &n); int vector[n]; printf("\nIshodniy Vector:\n"); m=vector_max-vector_min+1; for(i=0; i<n; i++) { vector[i]=rand()%m+vector_min; // Получение случайного числа в диапазоне от vector_min до vector_max printf("%5d", vector[i]); } printf("\n"); for(i=0; i<n; i++) printf("%5d", vector[i]); l=function(n, vector); printf("Srednee arifmeticheskoe znachenie majdu vtorim max i vtorim min=%0.5",l); } void function (int n, int j, int tmp, int *vector, int x) { int i, one, two, k=0, summ=0, *l; one=two=*vector; printf("\n"); for(i=0; i<n; i++) printf("%5d", *vector); i=0; k=0; one=0; two=0; int r=0; int fabs (int num) r=*vector - x; for (i=1;i<n;i++) { k=(*(vector+i)- x); if (fabs(k) > abs(l)) { r = k; one =*(vector+i); } else if (fabs(k) < abs(l)) { r = k; two =*(vector+i); } } for(i=0; i<n; i++) { printf("%5d", *vector); printf("\none=%d\n", one); // Выводим найденные элементы на экран printf("\ntwo=%d\n", two); } for(i=((one)+1); i<one; i++) { summ+=*(vector+i); k++; //считаем кол-во элементов которые мы суммируем для получения ср. арифметич. знач. printf("\nk=%d\n", k); } for(i = 0; i < size - 1; ++i) // i - номер прохода { for(j = 0; j < size - 1; ++j) // внутренний цикл прохода { if (arr[j + 1] < arr[j]) { tmp = arr[j + 1]; arr[j + 1] = arr[j]; arr[j] = tmp; } } } }[/C]
Сортировку и определение среднего арифметического нужно реализовать в одной подпрограмме, а не выносить в отдельную.


Часовой пояс GMT +4, время: 05:49.

Powered by vBulletin® Version 4.5.3
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.