- 1
result['first'] = False if page != 1 else True
Нашли или выдавили из себя код, который нельзя назвать нормальным, на который без улыбки не взглянешь? Не торопитесь его удалять или рефакторить, — запостите его на говнокод.ру, посмеёмся вместе!
−109
result['first'] = False if page != 1 else True
Неплохое такое выражение
+151
<?php
//----------------------------Сначала оригинал который был запосчен--------------------------------
$mas = array("odin", "dva", "tri");
function obm($mas[$i]){
if $mas[$i] = "odin" $mas[$i] = 1;
return $mas[$i];
if $mas[$i] = "dva" $mas[$i] = 2;
return $mas[$i];
if $mas[$i] = "tri" $mas[$i] = 3;
return $mas[$i];
}
$n = 0;
$new = array();
for ($i = 0; $i < 100; $i++) {
$n++;
$i = $n * $mas[$i];
}
//----------------------------- Конец оригинала ---------------------------------------------------------------
//--------------- Потом мне всбрело в голову прокаментить каждую строчку, вот что с этого получилось
$mas = array("odin", "dva", "tri");//Инициализация массива.
//Объявление функции.
function obm($mas[$i]){//Входящий параметр, массив с перемменной? Даже пхп такое не понимает. Ну бум считать что это просто переменная типа $mas_i
if $mas[$i] = "odin" $mas[$i] = 1;//Сравнение входящей переменной со строкой "odin", зачем было инциализировать массив, если совпадает, то мы массиву который раньше инициализировали присваеваем 1. Но так как это функция, то видимости массива тут нет, то есть основной не иземеняется. Просто создается внутренний и ему присвается значение. При этом у нас нету значения $i. По умолчанию будет $mas[0]. Также сама конструкция if сама по себе не правильная.
return $mas[$i];//Возвращение значения из массива, присвоенного ранее. Можно было бы в предедущей строчку сделать ретурн. При этом эта строчка будет выполнятся всегда. Так как если бы if был бы правильный, то он сработал бы только на первую операцию. И дальнейший код никогда бы не выполнялся.
if $mas[$i] = "dva" $mas[$i] = 2; //Ну тут аналогично первым двум строкам.
return $mas[$i];
if $mas[$i] = "tri" $mas[$i] = 3;
return $mas[$i];
}
//Функция то написана, но блин она же нигде не вызывается!
$n = 0;//Зачем-то инициализируем счетчик.
$new = array();//Инициализация нового массива.
for ($i = 0; $i < 100; $i++) {//Стар цикла от 0 до 99 с шагом 1 в переменную $i. Единственная правильная сктрока с осмысленным кодом во всем скрипте.
$n++;//К счетчику сразу пуляем +1, то есть он у нас является дубликатом переменной $i + 1
$i = $n * $mas[$i];//Тут я долго думал :-) Допустим первый проход в цикле. $i=0; $n=1; $mas[$i]='odin'. Имеем комбинацию $i = 1 * "odin"; Пхп пытается перевести "odin" в цисловую переменную, получает 1. Итого мы имеем 1 * 1 =1; Дальше лучше, следующий цикл $i=1; $n=2; $mas[$i]="dva"; $i = 2 * "dva"; То есть получаем в $i значение 2. В следующем цикле аналогично. $i=2;$n=3;$mas[$i]='tri';$i=3*'tri'=3; А вот следующая итерация уже достойна высшей математики :-) $i=3;$n=4; $mas[$i] то есть индекс 3, блин а нет таког, то есть пустая строка, и мы имеем далее $i=4 * "". Пхп интрепретирует пустую как ноль и в переменной $i получаем 0. Что сбрасывает цикл в самое начала. И если бы не растущий счетчик $n, то выхода из цикла бы вообще не было. На следующем шаге получается примерно такое $i=1;$n=5;$mas[$i]='dva';$i=5*"dva"=5. Следующая $i будет 6, потом 0, потом 8, потом 0 и т.д.
}
//И в конце концов мы ничего не получаем, так как нигде не использовали массив $new;
//-------------------------------------Конец каментов-----------------------------------------
//-------------Ну и чисто для стеба, решение задачи от меня в три строки---------
$Str = 'odin';
$mas = array("odin", "dva", "tri");
$num = array_search($Str, $mas)+1;
$new = range(0, $num*99, $num);
echo "new='".var_export($new, true)."'\n";
//-------------------------------------DIE() :-)---------------------------------------------------
Нашел на форуме.
Задача. На входе есть строка с содержанием odin, dva или tri. На выходе должен был получится массив со ста числами с шагом указанным в строке, то есть для строки tri, должен быть результат 0, 3, 6, 9, 12 ......294,297
И чел спрашивает, почему у меня код не работает :-) И как его пофиксить.
+68
int a, b ;
//some code
int numCount = 0;
while ((a + numCount++) < b) // посчитать кол-во чисел между a и b, включая a и b
;
это великолепно!
+1
public enum AdjacentCell {
/// <summary>
/// Сверху.
/// </summary>
Above = ABOVE,
/// <summary>
/// Снизу.
/// </summary>
Below = BELOW,
/// <summary>
/// Слева.
/// </summary>
Left = LEFT,
/// <summary>
/// Справа.
/// </summary>
Right = RIGHT
}
private const int ABOVE = 0;
private const int BELOW = 1;
private const int LEFT = 2;
private const int RIGHT = 3;
Мы добавили немного констант в твой енам, чтобы ты мог использовать константы, пока используешь енам
+94
SetLength(kokoko, Length(kokoko)+1);
kokoko[Length(kokoko)-1] := Something;
БЕСИТ
−115
def _make_parser_function(name, sep=','):
def parser_f(filepath_or_buffer,
sep=sep,
dialect=None,
compression=None,
doublequote=True,
escapechar=None,
quotechar='"',
quoting=csv.QUOTE_MINIMAL,
skipinitialspace=False,
lineterminator=None,
header='infer',
index_col=None,
names=None,
prefix=None,
skiprows=None,
skipfooter=None,
skip_footer=0,
na_values=None,
na_fvalues=None,
true_values=None,
false_values=None,
delimiter=None,
converters=None,
dtype=None,
usecols=None,
engine='c',
delim_whitespace=False,
as_recarray=False,
na_filter=True,
compact_ints=False,
use_unsigned=False,
low_memory=_c_parser_defaults['low_memory'],
buffer_lines=None,
warn_bad_lines=True,
error_bad_lines=True,
keep_default_na=True,
thousands=None,
comment=None,
decimal=b'.',
parse_dates=False,
keep_date_col=False,
dayfirst=False,
date_parser=None,
memory_map=False,
nrows=None,
iterator=False,
chunksize=None,
verbose=False,
encoding=None,
squeeze=False,
mangle_dupe_cols=True,
tupleize_cols=True,
):
# Alias sep -> delimiter.
if delimiter is None:
delimiter = sep
kwds = dict(delimiter=delimiter,
engine=engine,
dialect=dialect,
compression=compression,
doublequote=doublequote,
escapechar=escapechar,
quotechar=quotechar,
quoting=quoting,
skipinitialspace=skipinitialspace,
lineterminator=lineterminator,
header=header,
index_col=index_col,
names=names,
prefix=prefix,
skiprows=skiprows,
na_values=na_values,
na_fvalues=na_fvalues,
true_values=true_values,
false_values=false_values,
keep_default_na=keep_default_na,
thousands=thousands,
comment=comment,
decimal=decimal,
parse_dates=parse_dates,
keep_date_col=keep_date_col,
dayfirst=dayfirst,
date_parser=date_parser,
nrows=nrows,
iterator=iterator, ....
На самом деле оно в общем не такое уж и страшное потому что в питоне можно по имени аргументы в метод, но флешер в мне нервно икнул
+164
private static function getKey($len = 8)
{
global $db;
$chars = 'QWERTYUIOPASDFGHJKLZXCVBNM0123456789';
$key = '';
for ($i = 0; $i < $len; $i++)
{
$key .= substr($chars, rand(1, strlen($chars)) - 1, 1);
}
if ($db -> select(
'SELECT *
FROM ' . self::$t_main .
' WHERE `key` = "' . $key . '"'))
{
return ModelTickets::getKey();
}
return $key;
}
"Генератор" уникального ключа.
Автор кода когда-то хотел к нам на работу устроиться. Но всё как-то не срасталось, а потом другую работу нашёл. Я об этом долгое время жалел, но потом я нашёл вот этот код, за его авторством. И я понял, б-г есть, уберёг контору от страшного.
Рекурсия по базе данных - это надо иметь особый склад ума.
+2
int a,b,c,d,e,f, k = 1;
for (a = 0; a < 9; a++)
for (b = 0; b < 9; b++)
for (c = 0; c < 9; c++)
for (d = 0; d < 9; d++)
for (e = 0; e < 9; e++)
for (f = 0; f < 9; f++)
{
if (a + b + c == d + e + f && a+b+c == 13)
k = k + 1;
}
Console.WriteLine("кол-во комбинаций: " + k + " ");
Console.WriteLine("кол-во билетов: " + k * k);
Очередные лабы... God, whyyy...
+139
private string FormatblankInString(string value)
{
if (value.Contains("blank"))
{
if (value.Trim().EndsWith("blank"))
{
value = value.Replace("blank", "");
//if only blank pressent then
if (string.IsNullOrEmpty(value))
{
value = value.Insert(0, "blank");
}
else
{
if (value.EndsWith(","))
value = value.Remove(value.LastIndexOf(','));
value = value.Insert(0, "blank" + ",");
}
}
value = value.Replace("blank", "[blank]");
return value;
}
else
{
return value;
}
}
Продукт наших индусских коллег. Начнем с того, что на клиенсткой форме слова "blank" вообще быть не должно, там или значение или null, который не выводится. Но они его не только выводят, но и в базу сохраняют и делают с ним вот такую индусскую магию...
+135
int overflow(const char *str)
{
char buf[9000];
int res = atoi(buf);
itoa(res, buf, 10);
return strcmp(buf, str);
}
По мотивам #17745.