Byla vydána nová verze 9.20 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze například nový balíček RustDesk Server pro vzdálený přístup.
Jonathan Thomas oznámil vydání nové verze 3.4.0 video editoru OpenShot (Wikipedie). Představení novinek také na YouTube. Zdrojové kódy OpenShotu jsou k dispozici na GitHubu. Ke stažení je i balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit.
Byla vydána nová verze 1.6 otevřeného, licenčními poplatky nezatíženého, univerzálního ztrátového formátu komprese zvuku Opus (Wikipedie) a jeho referenční implementace libopus. Podrobnosti na demo stránce.
Vojtěch Polášek představil Vojtux, tj. linuxovou distribuci pro zrakově postižené uživatele. Vychází ze spinu Fedory 43 s desktopovým prostředím MATE. Konečným cílem je, aby žádný Vojtux nebyl potřeba a požadovaná vylepšení se dostala do upstreamu.
Byla vydána (Mastodon, 𝕏) druhá RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 160 (pdf).
Izrael od února zakáže dětem používat v prostorách základních škol mobilní telefony. Podle agentury AFP to uvedlo izraelské ministerstvo školství, které zdůraznilo negativní dopady, které na žactvo používání telefonů má. Izrael se tímto krokem přidává k rostoucímu počtu zemí, které dětem ve vzdělávacích zařízeních přístup k telefonům omezují.
Internetová společnost Google ze skupiny Alphabet pravděpodobně dostane příští rok pokutu od Evropské komise za nedostatečné dodržování pravidel proti upřednostňování vlastních služeb a produktů ve výsledcích vyhledávání. V březnu EK obvinila Google, že ve výsledcích vyhledávání upřednostňuje na úkor konkurence vlastní služby, například Google Shopping, Google Hotels a Google Flights. Případ staví Google proti specializovaným
… více »Byl oznámen program a spuštěna registrace na konferenci Prague PostgreSQL Developer Day 2026. Konference se koná 27. a 28. ledna a bude mít tři tracky s 18 přednáškami a jeden den workshopů.
Na webu československého síťařského setkání CSNOG 2026 je vyvěšený program, registrace a další informace k akci. CSNOG 2026 se uskuteční 21. a 22. ledna příštího roku a bude se i tentokrát konat ve Zlíně. Přednášky, kterých bude více než 30, budou opět rozdělené do tří bloků - správa sítí, legislativa a regulace a akademické projekty. Počet míst je omezený, proto kdo má zájem, měl by se registrovat co nejdříve.
Nemaje klasického informatického vzdělání byl jsem toho ve škole ušetřen. O čem mluvím? Všechny ty algoritmy pro třídění a tak. No a pak to člověk potřebuje a neví. Když už to zjistí, tak si to chce vytesat do kamene. Ehm do webu. Tak taky rozšířím zbytečně duplicitní stránky, na kterých je taková, nebo onaká implementace quicksortu. Až to zas někdy budu potřebovat a jestli bude abíčko ještě existovat, tak to třeba tady najdu.
#include <sys/time.h>
#include <stdio.h>
#include <stdlib.h>
#define timedif(start, stop) \
(u_int)((stop)->tv_sec - (start)->tv_sec - ((stop)->tv_usec < (start)->tv_usec))
#define utimedif(start, stop) \
(u_int)((stop)->tv_usec - (start)->tv_usec + 1000000*((stop)->tv_usec < (start)->tv_usec))
#define N (10000000)
#ifndef __u_char_defined
typedef __u_int u_int;
#endif
u_int numbers[N];
#define swap(i,j) \
{ register u_int pom=*i; *i=*j; *j=pom; }
void quicksort(u_int *start, u_int *end)
{
u_int *i, *low=start; /* low is place for pivot */
for(i=start; i<end; i++)
{
if(*i<*end) /* end element is pivot */
{
swap(i, low);
low++;
};
};
swap(low, end); /* place pivot to his place */
if(start<low-1)
quicksort(start, low-1);
if(low+1<end)
quicksort(low+1, end);
}
int main(void)
{
u_int rand_seed;
#ifdef __USE_BSD
struct timezone foo_;
struct timezone *foo=&foo_;
#else
void *foo=NULL;
#endif
struct timeval start, stop;
gettimeofday(&start, foo);
rand_seed = start.tv_usec;
srand(rand_seed);
{ /* init numbers */
u_int i;
for(i=0; i<N; i++)
numbers[i]=rand();
}
/* start measure */
gettimeofday(&start, foo);
quicksort(numbers, numbers+N-1);
/* measure time */
gettimeofday(&stop, foo);
printf("#Sorting %d numbers consumed %d.%06dsec\n",
N, timedif(&start, &stop), utimedif(&start, &stop));
{ /* test result */
u_int i;
char OK=1;
for(i=0; i<N-1 && (OK &= numbers[i]<= numbers[i+1]); i++);
printf(OK?"All OK.\n":"Something bad.\n");
return !OK;
}
}
P.S.: Tato implementace není vhodná pro částečně setříděné pole. Patch pro částečně setříděná pole:
@@ -20,6 +20,7 @@
void quicksort(u_int *start, u_int *end)
{
u_int *i, *low=start; /* low is place for pivot */
+ swap(start+(end-start)/2, end);
for(i=start; i<end; i++)
{
if(*i<*end) /* end element is pivot */
Tiskni
Sdílej:
viz http://en.wikipedia.org/wiki/Bogosort
for(i=start; i<end; i++)
{
if(*i<*end) /* end element is pivot */
{
swap(i, low);
low++;
};
};
Ta část jednoznačně provádí třídění na prvky menší než *end a na prvky nemenší. To je třídění jak vyšité. Je to třídící algoritmus na řazení rpvků.
start+(end-start)/2 lze napsat takto: (start+end)/2