IPB
ЛогинПароль:

> Внимание!

1. Пользуйтесь тегами кода. - [code] ... [/code]
2. Точно указывайте язык, название и версию компилятора (интерпретатора).
3. Название темы должно быть информативным.
В описании темы указываем язык!!!

Наладить общение поможет, если вы подпишитесь по почте на новые темы в этом форуме.

> [Java] среднее геометрическое
сообщение
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 38
Пол: Мужской

Репутация: -  0  +


Добрый День!!! smile.gif
помогите Пожалуйста написать метод, который будет в целочисленной матрице заменять все элементы средним геометрическим абсолютных значений их соседей.
Мой код, с добавлением "единичной" границы к матрице:
int SrGeom; 
int Product;
for(int i = 1; i < n+1; i++){
for(int j = 1;j < m+1; j++){
Product = Math.abs(unitmatrix[i-1][j]) * Math.abs(unitmatrix[i+1][j]) *
Math.abs(unitmatrix[i][j-1]) * Math.abs(unitmatrix[i][j+1]);
SrGeom = (int)Math.pow(Product, 0.25);
}
}
for (int i = 0; i < n; i++){
for (int j = 0; j < m; j++){
array[i][j] = SrGeom;
}
}
Помогите Пожалуйста переделать код, с подсчётом среднего геометрического через логарифмы или экспоненты и с правильной заменой
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
сообщение
Сообщение #2


Гуру
*****

Группа: Пользователи
Сообщений: 1 013
Пол: Мужской
Ада: Разработчик
Embarcadero Delphi: Сторонник
Free Pascal: Разработчик

Репутация: -  627  +


Я бы не стал менять на экспоненту с логарифмом. Pow прекрасно справляется с задачей. Единственное, что я бы сделал - это убрал бы добавление
Цитата
"единичной" границы к матрице:
. Вот так:

        public static int Count;

int Counter() {
Count -= 1;
return 1;
}

void Action() {
int [][] ca = new int [n][m];
for(int i = 0; i < n; i++)
for(int j = 0; j < m; j++) ca[i][j] = a[i][j];

for(int i = 0; i < n; i++) {
for(int j = 0; j < m; j++) {
Count = 4;
int Product = ((i > 0) ? Math.abs(ca[i-1][j]) : Counter()) *
((i < n - 1) ? Math.abs(ca[i+1][j]) : Counter()) *
((j > 0) ? Math.abs(ca[i][j-1]) : Counter()) *
((j < m - 1) ? Math.abs(ca[i][j+1]) : Counter());
int SrGeom = (int)Math.pow(Product, 1.0 / Count); // Вычисляем правильное значение
a[i][j] = SrGeom;
}
}
}
, у тебя среднее геометрическое вычисляется неверно. Если ты перемножал 2 элемента - то и корень должен быть квадратный, а не 4-ой степени. В твоем варианте значения на граничных элементах будут меньше, чем нужно.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Новичок
*

Группа: Пользователи
Сообщений: 38
Пол: Мужской

Репутация: -  0  +


Цитата(IUnknown @ 3.06.2011 11:14) *

Я бы не стал менять на экспоненту с логарифмом. Pow прекрасно справляется с задачей. Единственное, что я бы сделал - это убрал бы добавление . Вот так:

        public static int Count;

int Counter() {
Count -= 1;
return 1;
}

void Action() {
int [][] ca = new int [n][m];
for(int i = 0; i < n; i++)
for(int j = 0; j < m; j++) ca[i][j] = a[i][j];

for(int i = 0; i < n; i++) {
for(int j = 0; j < m; j++) {
Count = 4;
int Product = ((i > 0) ? Math.abs(ca[i-1][j]) : Counter()) *
((i < n - 1) ? Math.abs(ca[i+1][j]) : Counter()) *
((j > 0) ? Math.abs(ca[i][j-1]) : Counter()) *
((j < m - 1) ? Math.abs(ca[i][j+1]) : Counter());
int SrGeom = (int)Math.pow(Product, 1.0 / Count); // Вычисляем правильное значение
a[i][j] = SrGeom;
}
}
}
, у тебя среднее геометрическое вычисляется неверно. Если ты перемножал 2 элемента - то и корень должен быть квадратный, а не 4-ой степени. В твоем варианте значения на граничных элементах будут меньше, чем нужно.



Скажите Пожалуйста, а как учесть ещё и "диагональные соседи" при подсчёте ?
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 18.05.2024 4:20
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name