PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи

Страниц (31): В начало « ... 3 4 5 6 [7] 8 9 10 11 ... » В конец

> Найдено сообщений: 455
jonston Отправлено: 31 Января, 2014 - 22:21:29 • Тема: Генерация уникальных комбинаций двух массивов • Форум: Вопросы новичков

Ответов: 13
Просмотров: 935
LIME пишет:
jonston я извиняюсь за слишком спешный вывод но пробовать лениво

Без проблем.Заглядывай.Может свой вариант выложу.
jonston Отправлено: 31 Января, 2014 - 22:19:56 • Тема: Генерация уникальных комбинаций двух массивов • Форум: Вопросы новичков

Ответов: 13
Просмотров: 935
LIME пишет:
да...поспешили...
ясно что не декартово
но лениво...я удаляюсь)

Жаль.Неплохая практика.
jonston Отправлено: 31 Января, 2014 - 22:12:05 • Тема: Генерация уникальных комбинаций двух массивов • Форум: Вопросы новичков

Ответов: 13
Просмотров: 935
OrmaJever пишет:

По-моему это и не на первый взгляд не сложно Подмигивание


Не правильно.У тебя 9 элементов.А у массива который я дал выше 81.Возможно я не правильно сформулировал.

первый цикл:
'1-5', '2-5', '3-5' - первый, второй, и третий элемент первого массива взяли себе первый элемент второго
второй цикл:
'1-6', '2-5', '3-5' - все так же только первый элемент в комбинации со вторым элементом второго.И так далее.Получается уникальные ряды комбинаций.Ну вобщем нужно рассмотреть логику.
(Добавление)
LIME, Я реально говорю не так все просто.Попробуй.
jonston Отправлено: 31 Января, 2014 - 21:59:53 • Тема: Генерация уникальных комбинаций двух массивов • Форум: Вопросы новичков

Ответов: 13
Просмотров: 935
LIME пишет:
элементарно
декартово произведение
тут похлеще варианты подымались))
вложенные циклы
не интересно

Ну так напиши.Помоги мне.Будет у тебя 229 плюсов.
jonston Отправлено: 31 Января, 2014 - 21:52:32 • Тема: Генерация уникальных комбинаций двух массивов • Форум: Вопросы новичков

Ответов: 13
Просмотров: 935
Здравствуйте!Вот вам не тривиальный вопрос.
Есть два массива:
PHP:
скопировать код в буфер обмена
  1. $arr1 = array('1', '2', '3');
  2. $arr2 = array('5', '6', '7');

Нужно создать функцию которая возвращает все возможные комбинации между элементами этих двух массивов.
Для наглядности должен получится такой вот массив:
PHP:
скопировать код в буфер обмена
  1.     '1-5', '2-5', '3-5',
  2.     '1-6', '2-5', '3-5',
  3.     '1-7', '2-5', '3-5',
  4.      
  5.     '1-5', '2-6', '3-5',
  6.     '1-6', '2-6', '3-5',
  7.     '1-7', '2-6', '3-5',
  8.      
  9.     '1-5', '2-7', '3-5',
  10.     '1-6', '2-7', '3-5',
  11.     '1-7', '2-7', '3-5',
  12.    
  13.     '1-5', '2-5', '3-6',
  14.     '1-6', '2-5', '3-6',
  15.     '1-7', '2-5', '3-6',
  16.      
  17.     '1-5', '2-6', '3-6',
  18.     '1-6', '2-6', '3-6',
  19.     '1-7', '2-6', '3-6',
  20.      
  21.     '1-5', '2-7', '3-6',
  22.     '1-6', '2-7', '3-6',
  23.     '1-7', '2-7', '3-6',
  24.    
  25.     '1-5', '2-5', '3-7',
  26.     '1-6', '2-5', '3-7',
  27.     '1-7', '2-5', '3-7',
  28.      
  29.     '1-5', '2-6', '3-7',
  30.     '1-6', '2-6', '3-7',
  31.     '1-7', '2-6', '3-7',
  32.      
  33.     '1-5', '2-7', '3-7',
  34.     '1-6', '2-7', '3-7',
  35.     '1-7', '2-7', '3-7',
  36. );

На первый взгляд кажется что легко, но столкнувшись понимаешь что не все так просто.
jonston Отправлено: 26 Января, 2014 - 20:55:48 • Тема: Вывод ошибок mysql • Форум: Вопросы новичков

Ответов: 4
Просмотров: 211
DeepVarvar пишет:
Насколько помню Вы там в кодигнайтере колдуете. Не понимаю откуда взялась проблема в такой простейшей задаче.

Ну не только.Сейчас вариант на чистом php.
jonston Отправлено: 26 Января, 2014 - 16:10:41 • Тема: Вывод ошибок mysql • Форум: Вопросы новичков

Ответов: 4
Просмотров: 211
DeepVarvar пишет:
PHP:
скопировать код в буфер обмена
  1. if ($mysqlError = mysql_error($resource)) {
  2.   throw new Exception($mysqlError);
  3. }


Это нужно объявить в начале скрипта?
jonston Отправлено: 26 Января, 2014 - 14:55:35 • Тема: Вывод ошибок mysql • Форум: Вопросы новичков

Ответов: 4
Просмотров: 211
Как автоматически вывести ошибки mysql.display_errors выставлено on и error_reporting = E_ALL.Но ошибки типа 'unknown column in field list' не выводятся.Почему?И как исправить?
jonston Отправлено: 26 Января, 2014 - 14:52:57 • Тема: порядок выборки • Форум: Вопросы новичков

Ответов: 13
Просмотров: 464
EuGen пишет:
Потому что он сортирует по значению выражения "int=0". Это значение будет равно 1, если int в самом деле 0 (ведь 0=0) или 0, если int не равен 0 (поскольку всё, что угодно, кроме 0, не равно 0). Поэтому сначала будут идти строки, у которых значение выражения "int=0" равно 0 (то есть всё, где int не 0), затем те, у которых значение выражения "int=0" равно 1 (то есть все те, у которых int=0)

Да спасибо.Я понял попрактиковавшись.То есть он создает как бы новое поле в памяти и присваивает ему значение выражения int = 0 и потом сортирует уже в соответствии с ним.
jonston Отправлено: 25 Января, 2014 - 20:52:20 • Тема: порядок выборки • Форум: Вопросы новичков

Ответов: 13
Просмотров: 464
Мелкий пишет:
Ну я и говорю, постоянно путаю направления сортировок...

Не, не, не.Смотри.Первое интерпретатор понимает как отобрать все нулевые значения по возрастанию (то есть нули), а потом уже int asc (остальные от 1+...)
jonston Отправлено: 25 Января, 2014 - 20:41:32 • Тема: порядок выборки • Форум: Вопросы новичков

Ответов: 13
Просмотров: 464
Мелкий пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT int, int=0 AS firstsort, int AS secondsort FROM `table` ORDER BY firstsort, secondsort ASC

Увидите, что сперва отсортировано по столбцу, содержащему только 0 или 1 (результат сравнения int=0), а строки, имеющие одинаковые значения по первому столбцу - уже выполнена сортировка по значению int

Примерно понял.Только почему в запросе
CODE (SQL):
скопировать код в буфер обмена
  1. ORDER BY int = 0, int ASC

Выводятся сначала все от 1 по возрастающей, а потом уже нули.Ведь по логике должные нули, а потом все по возрастающей?
jonston Отправлено: 25 Января, 2014 - 20:06:51 • Тема: порядок выборки • Форум: Вопросы новичков

Ответов: 13
Просмотров: 464
green_man пишет:
Первое что приходит на ум это конечно union, а так подумать надо.
Решил уже.Мелкий подсказал почти правильный вариант.Только вмеcто > z я поставил =.
jonston Отправлено: 25 Января, 2014 - 18:47:20 • Тема: порядок выборки • Форум: Вопросы новичков

Ответов: 13
Просмотров: 464
green_man пишет:
Зачем именно такой порядок?
Неудобно цикл делать?Улыбка


Ну смотри если тебе интересно.Есть города и регионы (все в одной таблице.Знаю что не удобно но переделывать не вариант).У них есть поле порядок сортировки.Для удобства использования нужно выводить Республика Адыгея, Майкоп и так далее.То есть Регион и столица региона.Контентщик отсортировал все регионы и города в порядке возрастания по алфавиту.То есть Адыгея идет первой по алфавиту и потом должен идти региональный центр - Майкоп.Соответственно 1 и 2.И так далее.Но остались еще города у которых по умолчанию стоит ноль (не региональные центры но нужные крупные города).Если выводить все по порядку, то нулевые будут первыми.А в приоритете должны быть регионы и их столицы.Не знаю доходчиво ли описал, но как смог.
jonston Отправлено: 25 Января, 2014 - 18:21:07 • Тема: порядок выборки • Форум: Вопросы новичков

Ответов: 13
Просмотров: 464
Мелкий пишет:
По старому обыкновению, мог напутать ASC/DESC

Не получается.Все равно нули первые.
(Добавление)
Мелкий пишет:
По старому обыкновению, мог напутать ASC/DESC


помогло
CODE (SQL):
скопировать код в буфер обмена
  1. ORDER BY  int = 0, int ASC
.Объясните пожалуйста как компилятор обрабатывает сей запрос.А то что то не доходит.
jonston Отправлено: 25 Января, 2014 - 00:27:04 • Тема: порядок выборки • Форум: Вопросы новичков

Ответов: 13
Просмотров: 464
Здравствуйте.Есть поле (int) в таблице по которой осуществляется сортировка записей.Как сделать что бы скрип выбрал все от 1 по возрастанию, а потом уже нули?

Страниц (31): В начало « ... 3 4 5 6 [7] 8 9 10 11 ... » В конец
Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB