#include <stdio.h> int main(){ int i; while( 1 ){ scanf("%d", &i); if( i == 42 ) break; printf("%d\n", i); } return 0; }
piątek, 28 września 2012
LIFE, THE UNIVERSE, AND EVERYTHING
sobota, 3 marca 2012
Array unique - czyli pozbywamy się duplikatów
Funkcja jako argument przyjmuje tablicę z danymi dowolnego typu. W rezultacie funkcja zwraca tablicę zawierającą tylko unikalne elementy tablicy źródłowej.
var unique = function(arr){ return arr.filter(function(el, i){ return arr.indexOf(el, i+1) === -1; }); };Poniżej zamieszczam funkcję robiącą to samo co powyższa funkcja z drobnym wyjątkiem. Poniższa funkcja zawiera dwa dodatkowe wykonania funkcji reverse co pozwoliło na zachowanie naturalnej kolejności elementów występujących w tablicy. Pierwsze wystąpienie danego elementu pozostaje w tym samym miejscu, kolejne wystąpienia tego samego elementu są ignorowane. W poprzedniej wersji funkcji to ostatni element zostałby zachowany.
var unique = function(arr){ return arr.reverse().filter(function(el, i){ return arr.indexOf(el, i+1) === -1; }).reverse(); };
let unique = [...new Set(myArray)];
środa, 22 lutego 2012
getType - sprawdzenie typu, pewniejsze od typeof
Poniżej zamieszczam funkcję zwracającą typ danej. Funkcja w przeciwieństwie do operatora typeof znacznie skuteczniej oddaje typ przekazanej danej. Pomysł został zaczerpnięty z serwisu JavaScript Garden. Funkcja do sprawdzenia typu wykorzystuje generyczną funkcję toString podstawowego obiektu.
var getType = function(obj){ return ({}).toString.call(obj).slice(8, -1); };Poniżej szybkie sprawdzenie różnic funkcji getType oraz operatora typeof. Pomaga on uświadomić sobie, z jakimi problemami mamy do czynienia, jeśli używamy operatora typeof.
[{}, [], '', 0, 1/0, false, function(){}, /./, null, undefined].map(function(obj){ return [getType(obj), typeof obj]; });Tak naprawdę operator typeof JavaScriptu ma tylko jedno uzasadnione zastosowanie.
typeof variable === 'undefined';
Subskrybuj:
Posty (Atom)