Поиск

топ 100 блогов lex_kravetski30.08.2012 Кстати, придумал задачу для любителей запаха монад по утрам, да и вообще для заинтересованных.

Есть у нас данные на сетке. Для простоты они сложены в двумерный массив. Данные намерянны каким-то прибором, который мог сломаться, что мы, в частности, узнаём по наличию в любой точке сетки значения, превышающего заранее заданную величину maxValue. Нам надо выяснить, не сломался ли прибор как минимум по этому критерию, но не просто выяснить, а ещё показать любое значение, превысившее максимальное — чисто для пафоса. У вас-де вот в этой точке аж вот столько, чините прибор.

Решение задачи с императивным подходом просто и прозаично.

int value = 0; 
a: for (int x = 0; x < xSize; x++) {
    for (int y = 0; y < ySize; y++) {
        int v = data[x][y];
        if (v > maxValue) {
            value = v;
            break a;
        }
    }
}


Прозаично, понятно и правильно работает, но не круто. Круто написать то же самое не просто на Scala, но с for-comprehension или с использованием каких-то методов scala-коллекций и без break. При этом написать так, чтобы оно было короче и не имело существенных просадок по производительности в сравнении с данным конкретным примером.

Дерзайте, друзья.

Оставить комментарий

Предыдущие записи блогера :
Архив записей в блогах:
КИЕВСКИЕ НЕДОТЫКОМКИ СНЕСЛИ ВЧЕРА ЕЩЁ ОДИН ШЕДЕВР Снесён памятник экипажу бронепоезда «Таращанец». Это монумент в честь героев красноармейского бронепоезда «Таращанец», которые в августе 1919 года почти 6 суток защищали от деникинцев Дарницкий железнодорожный узел. В ночь на 30 ...
Моя новая статья в NewtimesМаленький принц над Планетой ...
С 15 сентября 2013 года в Москве заработала платная эвакуация автомобилей припаркованных с нарушением правил дорожного движения, а именно стоянки и остановки. С тех самых пор, привычной картиной для центральной части города, стало паркование эвакуаторов Департамента транспорта города ...
1. Мы друзья 2. Ваш СК больше 10 3. Пара комментариев по теме поста: 1 комментарий - первого уровня, 2- ответ на чей =-либо комментарий. не торопимся. Ваши комментарии должны быть как можно дальше друг от друга. 4. Оплата 10 ЖЖ 5. Всего 20 исполнителей 6. 1ip= 1 исполнитель ПОСТ - ...
Хлопковая пряжа, буковые, липовые и можжевеловые бусины, вощеный шнур. Цена ...