Модераторы: skyboy, MoLeX, Aliance, ksnk
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Вывести метки (tags) по популярности 
:(
    Опции темы
InfectedM
Дата 12.9.2015, 12:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 74
Регистрация: 21.10.2007

Репутация: нет
Всего: нет



Не прошу код, нужна только идея и примерный алгоритм...подскажите плиз...

Есть css классы:
big-1 ... big-5 , который настраивают величину шрифта

есть запрос который возвращает сумму использования меток.
 
Код

SELECT tag_post.tag as id,count(tag_post.tag) as count_a,tags.name from tag_post
LEFT JOIN tags ON tag_post.tag = tags.id
group by tag_post.tag
order by  count_a desc limit 10

допустим вернул:

Яблоки - 10
Ананасы - 1
Молоко - 100
Анчоус: 1
Рыба: 2
Арахис: 1
Семечки: 3

Далее:
1) ищем максимальную сумму (т.е. 100)
3) делим 100 на 5 получаем получаем 20
 формируем облако меток:
Код


$result=20;
if ($count < $result*1)
{big-1}
if ($count < $result*2)
{big-2}
if ($count < $result*3)
{big-3}
if ($count < $result*4)
{big-4}
if ($count < $result*5)
{big-5}

 



Но если у нас будет:

Яблоки - 1000
Ананасы - 1
Молоко - 100
Анчоус: 1
Рыба: 2
Арахис: 1
Семечки: 3

1000 / 5 = 200
if < 200 {big-5}; if < 400{big-5} if < 600{big-5} if < 800{big-5} if <1000{big-5}

тогда все будут big-1 , кроме яблок, яблоки будут big-5
Молоко тоже популярно, но оно будет меньше 200, значит войдет в big-1
подскажите плиз еще какое-нибудь решение....

Это сообщение отредактировал(а) InfectedM - 12.9.2015, 12:41
PM MAIL   Вверх
Gold Dragon
Дата 14.9.2015, 21:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Призрачный
****


Профиль
Группа: Экс. модератор
Сообщений: 6753
Регистрация: 1.3.2004
Где: Россия, Тамбов

Репутация: 10
Всего: 71



только идея (я бы код написал, но сказал что не нужно  smile )
- помести всё в массив
- отсортируй по значению
- в цикле присвой нужные значения первым 4-м, остальным 5-й

PS
не надо делать так 
Код
[
    'яблоки' => 100,
    'Ананасы' => 50,
    'Рыба' => 25
]

Достаточно по идентификатору массив формировать
Код
[
    '1' => 100,
    '2' => 50,
    '3' => 25
]



--------------------
Нельзя жить в прошлом, оно уже прошло.
Нельзя жить в будущем, оно ещё не наступило.
Нужно жить в настоящем, помня прошлое и думая о будущем!
PM MAIL WWW ICQ   Вверх
InfectedM
Дата 15.9.2015, 23:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 74
Регистрация: 21.10.2007

Репутация: нет
Всего: нет



оо, то что нужно , спс.

 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "PHP"
Aliance
IZ@TOP
skyboy
SamDark
MoLeX

Новичкам:

  • PHP редакторы собираются и обсуждаются здесь
  • Электронные книги по PHP, документацию можно найти здесь
  • Интерпретатор PHP, полную документацию можно скачать на PHP.NET

Важно:

  • Не брезгуйте пользоваться тегами [code=php]КОД[/code] для повышения читабельности текста/кода.
  • Перед созданием новой темы воспользуйтесь поиском и загляните в FAQ
  • Действия модераторов можно обсудить здесь

Внимание:

  • Темы "ищу скрипт", "подскажите скрипт" и т.п. будут переноситься в форум "Web-технологии"
  • Темы с именами: "Срочно", "помогите", "не знаю как делать" будут УДАЛЯТЬСЯ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, IZ@TOP, skyboy, SamDark, MoLeX, awers.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1160 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.