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

Даны действительное число х и массив A[n]

19.04.2020, 21:12. Показов 986. Ответов 5
Метки java (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите, пожалуйста, разобраться с заданием.

Даны действительное число х и массив A[n].
В массиве найти два члена, среднее арифметическое которых ближе всего к х.

не могу никак разобраться((((

Java
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
import static java.lang.System.out;
import java.util.Scanner;
import java.util.Arrays;
import java.util.Random;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;
 
public class lr2 {
    /* Даны действительное число х и массив A[n]. В массиве найти два члена, среднее 
     * арифметическое которых ближе всего к х.
     */
public static void main(String[] args) {
     int a,b,x;                                                 
   
     Scanner in = new Scanner(System.in);
    out.print("Введите действительное число х : ");
    x = in.nextInt(); 
    out.print("Введите количество строк массива: ");
    a = in.nextInt();
          
   out.print("Введите количество столбцов массива: ");
   b = in.nextInt();
   in.close();
   int[][] arr = new int[a][b];
  
   Random rand = new Random();
   for (int i = 0; i < a; i++) {
       for (int j = 0; j < b; j++) {
           arr[i][j] = rand.nextInt(10);
    
       }   }
 for (int i = 0; i < a; i++) {
       for (int j = 0; j < b; j++)
        System.out.print(arr[i][j]+ " ");
        System.out.println();       
   }
 int summ =0;
 do {   
      
      for (int i = 0; i < a; i++) {
      for (int j = 0; j < b; j++) 
      summ = arr[i][j] + arr[i+1][j+1];
                } } 
                    while (summ !=x)  ;         
    
 System.out.println(summ);
}}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.04.2020, 21:12
Ответы с готовыми решениями:

Даны натуральное число n и действительное число x. Вычислить S=sinx+sinx2+…+ sinxn
Разработать алгоритм и по нему составить программу для вычисления заданной величины, определив её зависимость от параметра. Из условий...

Даны натуральное число n, действительное число а. Выдать на экран последовательность чисел: а, а+1!, а+2!, а+3!, . , а+п!
вот есть програма которая просто виводит последовательность чисел без факториала: а, а+1, а+2, а+3, ... , а+n. а мне нужно с факториалом....

Даны действительное число а, натуральное число n. Вычислить значение выражения.
Даны действительное число а, натуральное число n. Вычислить: 1/a+1/a*(a+1)+...+1/a*(a+1)...(a+n);

5
 Аватар для StepFather322
365 / 252 / 113
Регистрация: 07.10.2017
Сообщений: 1,330
19.04.2020, 21:32
Цитата Сообщение от Dudoffa Посмотреть сообщение
и массив A[n].
Цитата Сообщение от Dudoffa Посмотреть сообщение
out.print("Введите количество строк массива: ");
    a = in.nextInt();
out.print("Введите количество столбцов массива: ");
так массив одномерный или двумерный?
0
1 / 1 / 0
Регистрация: 15.04.2020
Сообщений: 9
19.04.2020, 21:34  [ТС]
добрый вечер, да, массив двумерный(((
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
19.04.2020, 21:59
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
double[] a = {1, 2, 3, 4, 5, 6, 7};
        double x = 3.5;
        double min = Double.MAX_VALUE;
        int minI = 0;
        int minJ = 0;
        for (int i = 0; i < a.length - 1; i++) {
            for (int j = i + 1; j < a.length; j++) {
                double avg = (a[i] + a[j]) / 2;
                double diff = Math.abs(x - avg);
                if (diff < min) {
                    min = diff;
                    minI = i;
                    minJ = j;
                }
            }
        }
        System.out.printf("a[%d] = %f%n", minI, a[minI]);
        System.out.printf("a[%d] = %f%n", minJ, a[minJ]);
Добавлено через 22 секунды
для двумерного сам переделаешь
0
 Аватар для Aviz__
2739 / 2048 / 507
Регистрация: 17.02.2014
Сообщений: 9,467
20.04.2020, 13:11
Dudoffa, держи, к Пасхе, в кодоКладовке покопался и чуток подправил для тебя
Кликните здесь для просмотра всего текста

Java
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
import java.util.Arrays;
import java.util.Iterator;
import java.util.concurrent.ThreadLocalRandom;
 
public class Helper {
 
    public static void main(String[] args) {
        Double[][] mat = getMatrix(2, 4, true);
        printMatrix(mat);
        double num = 3;
        System.out.println(Arrays.toString(getPairElemAverageMinDistToNam(mat, num)) + " -> " + num);
    }
 
    private static Double[] getPairElemAverageMinDistToNam(Double[][] twoDimArray, double aNum) {
        ForwardMatrixIterator<Double> frwdHight = new ForwardMatrixIterator<>(twoDimArray);
        ForwardMatrixIterator<Double> frwdLow = new ForwardMatrixIterator<>(twoDimArray);
        double minDist = Double.MAX_VALUE;
        double averege;
        Double[] findElems = new Double[2];
        Double[] curElems = new Double[2];
        while (frwdHight.hasNext()) {
            curElems[0] = frwdHight.next();
            while (frwdLow.hasNext()) {
                curElems[1] = frwdLow.next();
                if (frwdHight.getCounterElemFromBegin() < frwdLow.getCounterElemFromBegin()) {
                    averege = (curElems[0] + curElems[1]) / 2;
                    if (Math.abs(aNum - averege) < minDist) {
                        findElems[0] = curElems[0];
                        findElems[1] = curElems[1];
                        minDist = Math.abs(aNum - averege);
                    }
                }
            }
            frwdLow.reset();
        }
        return findElems;
    }
 
    private static Double [][] getMatrix(int row, int col, boolean notEmpty) {
        Double [][] retMat = new Double[row][col];
        if (notEmpty) {
            for (Double[] rowMat : retMat)
                for (int i = 0; i < col; i++) {
                    rowMat[i] = ThreadLocalRandom.current().nextDouble(0, 10);
                }
        }
        return retMat;
    }
 
    private static void printMatrix(Double[][] matPrint) {
        for (Double[] row : matPrint) {
            for (Double elemRow : row) {
                System.out.printf("%.2f |", elemRow);
            }
            System.out.println();
        }
        System.out.println("===========");
    }
 
}
 
class ForwardMatrixIterator<T extends Number> implements Iterator<Number> {
    private T[][] matrx;
    private int rowCurElem = 0;
    private int colCurElem = 0;
    private int counterElemFromBegin = 0;
 
    ForwardMatrixIterator(T[][] firstMatrix) {
        this.matrx = firstMatrix;
    }
 
    @Override
    public boolean hasNext() {
        if (colCurElem < matrx[rowCurElem].length) {
            return true;
        } else {
            colCurElem = 0;
            rowCurElem++;
        }
        return rowCurElem < matrx.length;
    }
 
    @Override
    public T next() {
        counterElemFromBegin++;
        return matrx[rowCurElem][colCurElem++];
    }
 
    public int getCounterElemFromBegin() {
        return counterElemFromBegin;
    }
 
    public void reset() {
        rowCurElem = 0;
        colCurElem = 0;
    }
 
    public int getSizeMatrix() {
        int size = matrx.length;
        for (T[] row : matrx)
            size += row.length;
        return size;
    }
}
 
class BackwardMatrixIterator<T extends Number> implements Iterator<Number> {
    private T[][] matrx;
    private int rowCurElem;
    private int colCurElem;
    private int counterElemFromEnd = 0;
 
    BackwardMatrixIterator(T[][] matrx) {
        this.matrx = matrx;
        this.rowCurElem = matrx.length - 1;
        this.colCurElem = matrx[matrx.length - 1].length - 1;
    }
 
    @Override
    public boolean hasNext() {
        if (colCurElem >= 0) {
            return true;
        } else {
            colCurElem = matrx[rowCurElem].length - 1;
            rowCurElem--;
        }
        return rowCurElem >= 0;
    }
 
    @Override
    public T next() {
        counterElemFromEnd++;
        return matrx[rowCurElem][colCurElem--];
    }
 
    public int getCounterElemFromEnd() {
        return counterElemFromEnd;
    }
 
    public void reset() {
        rowCurElem = matrx.length - 1;
        colCurElem = matrx[matrx.length - 1].length - 1;
    }
 
    public int getSizeMatrix() {
        int size = matrx.length;
        for (T[] row : matrx)
            size += row.length;
        return size;
    }
}

обратный итератор BackwardMatrixIterator тебе, для этой задачи не нужен, но на будущее))
резулт:
1,86 |4,34 |9,49 |2,72 |
6,12 |2,49 |1,32 |1,28 |
===========
[1.8614668264494183, 4.336084262358359] -> 3.0
0
1 / 1 / 0
Регистрация: 15.04.2020
Сообщений: 9
22.04.2020, 10:10  [ТС]
К Пасхе получить особенно приятно)))) Спасибо большое))
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.04.2020, 10:10
Помогаю со студенческими работами здесь

Даны натуральное число k, действительное число а (а > 0). Последовательность x0, x1,… образована по закону:
Даны натуральное число k, действительное число а (а &gt; 0). Последовательность x0, x1,… образована по закону x0=a , xi=(k-1/k)*xi-1 +...

Даны действительное число а, натуральное число n. Вычислить значение выражения
Добрый вечер. Нужна помощь в решении задачи 78(в) из задачника по программированию Абрамова. &quot;Даны действительное число а,...

Даны натуральное число n и действительное число x. Вычислить ряд.
Даны натуральное число n и действительное число x....

Даны натуральное число n, действительное число x. Вычислить произведения
В и Г

Даны действительное число a, натуральное число n. Вычис- лить:
Даны действительное число a, натуральное число n. Вычис- лить:...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru