abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 23:22 | IT novinky

    Evropský parlament dnes přijal směrnici týkající se tzv. práva spotřebitele na opravu. Poslanci ji podpořili 584 hlasy (3 bylo proti a 14 se zdrželo hlasování). Směrnice ujasňuje povinnosti výrobců opravovat zboží a motivovat spotřebitele k tomu, aby si výrobky nechávali opravit a prodloužili tak jejich životnost.

    Ladislav Hagara | Komentářů: 1
    včera 16:11 | Nová verze

    Bylo oznámeno (cs) vydání Fedora Linuxu 40. Přehled novinek ve Fedora Workstation 40 a Fedora KDE 40 na stránkách Fedora Magazinu. Současně byl oznámen notebook Slimbook Fedora 2.

    Ladislav Hagara | Komentářů: 4
    včera 13:44 | Upozornění

    ČTK (Česká tisková kancelář) upozorňuje (X), že na jejím zpravodajském webu České noviny byly dnes dopoledne neznámým útočníkem umístěny dva smyšlené texty, které nepocházejí z její produkce. Jde o text s titulkem „BIS zabránila pokusu o atentát na nově zvoleného slovenského prezidenta Petra Pelligriniho“ a o údajné mimořádné prohlášení ministra Lipavského k témuž. Tyto dezinformace byly útočníky zveřejněny i s příslušnými notifikacemi v mobilní aplikaci Českých novin. ČTK ve svém zpravodajském servisu žádnou informaci v tomto znění nevydala.

    Ladislav Hagara | Komentářů: 15
    včera 13:33 | Komunita

    Byla založena nadace Open Home Foundation zastřešující více než 240 projektů, standardů, ovladačů a knihoven (Home Assistant, ESPHome, Zigpy, Piper, Improv Wi-Fi, Wyoming, …) pro otevřenou chytrou domácnost s důrazem na soukromí, možnost výběru a udržitelnost.

    Ladislav Hagara | Komentářů: 0
    včera 13:00 | Nová verze

    Společnost Meta otevírá svůj operační systém Meta Horizon OS pro headsety pro virtuální a rozšířenou realitu. Vedle Meta Quest se bude používat i v připravovaných headsetech od Asusu a Lenova.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

    Ladislav Hagara | Komentářů: 0
    22.4. 23:44 | Nová verze

    Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    22.4. 16:44 | Zajímavý článek

    50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.

    Ladislav Hagara | Komentářů: 2
    22.4. 16:22 | Pozvánky

    Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.

    TomasVondra | Komentářů: 0
    22.4. 03:00 | IT novinky

    Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].

    Ladislav Hagara | Komentářů: 6
    KDE Plasma 6
     (72%)
     (10%)
     (2%)
     (17%)
    Celkem 699 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    19.2.2014 12:40 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Sudoku backtraking

    Postupy tohoto typu mi připadějí poněkud na šavli:

    for k := e to kanpol[10]-1 do   {zakaz policko}
                        begin
                             kanpol[k] := kanpol[k+1];
                        end;
    

    Těžko říct, jestli je horší to neustálé procházení a přepisování pole nebo nadužívání magických konstant. Chybu bych v celém tom kódu asi v dohledné době nenašel, protože odporný jazyk zvaný Packal jsem už notnou dobu nepoužíval.

    Místo toho jsem si jen tak pro legraci před chvílí nějaké Sudoku naprogramoval. Pořádně jsem ho netestoval, takže není vůbec jisté, že negeneruje nesmysly. :-) Algoritmus je založený na Dancing Links, které popisuje Donald Knuth ve svém legendárním článku. Triviálně se dá přepnout na jiný typ Sudoku, třeba 2x2 nebo 4x4. Stačí jenom změnit konstantu SIDE. Snadno se taky dá tento generátor Sudoku upravit na řešítko Sudoku, které vypíše všechna řešení, existují-li nějaká. Stačí načíst zadání, hodnoty zafixovaných políček zvolit pomocí Listing::hide() (což sice obnáší průchod jedním celým spojákem u každého políčka, ovšem každým jenom jednou) a pak spustit na takto upravené datové struktuře celý algoritmus. Zdá se, že všech 288 existujících Sudoku typu 2x2 mi to generuje správně. V případě 3x3 nebo 4x4 bych se hodně načekal. ;-)

    #include <iostream>
    #include <type_traits>
    #include <iomanip>
    #include <new>
    
    static const size_t
        SIDE = 3,
        SIDE_2 = SIDE * SIDE,
        SIDE_4 = SIDE_2 * SIDE_2;
    
    static const size_t
        FILL = (10 + SIDE_2) / 10 + 1;
    
    class Assignment;
    class Listing;
    class Field;
    class Tile;
    class Row;
    class Column;
    class Board;
    
    class Listing {
    protected:
        Assignment    *fieldPrev;
        Assignment    *fieldNext;
        Assignment    *tilePrev;
        Assignment    *tileNext;
        Assignment    *rowPrev;
        Assignment    *rowNext;
        Assignment    *columnPrev;
        Assignment    *columnNext;
    
        inline operator Assignment *();
        inline void discard();
    
    public:
        inline Listing();
        inline Listing(Field &field, Tile &tile, Row &row, Column &column);
        inline Assignment* prev() const;
        inline Assignment* next() const;
        inline ~Listing();
    };
    
    class Assignment : public Listing {
        Assignment        *hidingOrder;
        const size_t    value;
    
        inline void fieldHide(Assignment **order);
        inline void fieldShow();
    
    public:
        inline Assignment(Field &field, Tile &tile, Row &row, Column &column, size_t value_);
        inline operator size_t() const;
        inline void hide(Assignment **order);
        inline void show(Assignment *order);
    };
    
    class Field : public Listing {
        size_t    value;
    
    public:
        inline Field(Tile (&tile)[SIDE_2], Row (&row)[SIDE_2], Column (&column)[SIDE_2]);
        inline operator size_t() const;
        inline void fieldRecurse(Board &board, size_t level);
        inline void operator delete(void*);
        inline ~Field();
    };
    
    class Tile : public Listing {
    };
    
    class Row : public Listing {
    };
    
    class Column : public Listing {
    };
    
    class Board {
        typedef std::aligned_storage<sizeof(Field), alignof(Field)>::type    FieldPod;
        FieldPod    fields[SIDE_4];
    
    public:
        inline Board();
        inline Field& operator [](size_t idx);
        inline ~Board();
    };
    
    std::ostream& operator <<(std::ostream &stream, const Field &field);
    static inline void recurse(Board &board, size_t level);
    
    inline
    Listing::operator Assignment *() {
        return static_cast<Assignment *>(this);
    }
    
    inline
    Listing::Listing() :
        fieldPrev(static_cast<Assignment *>(this)),
        fieldNext(static_cast<Assignment *>(this)),
        tilePrev(static_cast<Assignment *>(this)),
        tileNext(static_cast<Assignment *>(this)),
        rowPrev(static_cast<Assignment *>(this)),
        rowNext(static_cast<Assignment *>(this)),
        columnPrev(static_cast<Assignment *>(this)),
        columnNext(static_cast<Assignment *>(this))
    {}
    
    inline
    Listing::Listing(Field &field, Tile &tile, Row &row, Column &column) :
        fieldPrev(field.fieldPrev),
        fieldNext(static_cast<Assignment *>(static_cast<Listing *>(&field))),
        tilePrev(tile.tilePrev),
        tileNext(static_cast<Assignment *>(static_cast<Listing *>(&tile))),
        rowPrev(row.rowPrev),
        rowNext(static_cast<Assignment *>(static_cast<Listing *>(&row))),
        columnPrev(column.columnPrev),
        columnNext(static_cast<Assignment *>(static_cast<Listing *>(&column)))
    {
        field.fieldPrev = static_cast<Assignment *>(this);
        fieldPrev->fieldNext = static_cast<Assignment *>(this);
        tile.tilePrev = static_cast<Assignment *>(this);
        tilePrev->tileNext = static_cast<Assignment *>(this);
        row.rowPrev = static_cast<Assignment *>(this);
        rowPrev->rowNext = static_cast<Assignment *>(this);
        column.columnPrev = static_cast<Assignment *>(this);
        columnPrev->columnNext = static_cast<Assignment *>(this);
    }
    
    inline Assignment*
    Listing::prev() const {
        return fieldPrev;
    }
    
    inline Assignment*
    Listing::next() const {
        return fieldNext;
    }
    
    inline void
    Listing::discard() {
        fieldPrev = *this;
        fieldNext = *this;
    }
    
    inline
    Listing::~Listing() {
        fieldPrev->fieldNext = fieldNext;
        fieldNext->fieldPrev = fieldPrev;
        tilePrev->tileNext = tileNext;
        tileNext->tilePrev = tilePrev;
        rowPrev->rowNext = rowNext;
        rowNext->rowPrev = rowPrev;
        columnPrev->columnNext = columnNext;
        columnNext->columnPrev = columnPrev;
    }
    
    inline
    Assignment::Assignment(Field &field, Tile &tile, Row &row, Column &column, size_t value_) :
        Listing(field, tile, row, column),
        value(value_)
    {}
    
    inline
    Assignment::operator size_t() const {
        return value;
    }
    
    inline void
    Assignment::fieldHide(Assignment **order) {
        if (*this == fieldNext->fieldPrev) {
            fieldPrev->fieldNext = fieldNext;
            fieldNext->fieldPrev = fieldPrev;
            hidingOrder = *order;
            *order = this;
        }
    }
    
    inline void
    Assignment::hide(Assignment **order) {
        for (Assignment *as = tileNext; *this != as; as = as->tileNext) as->fieldHide(order);
        for (Assignment *as = rowNext; *this != as; as = as->rowNext) as->fieldHide(order);
        for (Assignment *as = columnNext; *this != as; as = as->columnNext) as->fieldHide(order);
        fieldPrev->fieldNext = fieldNext;
        fieldNext->fieldPrev = fieldPrev;
        hidingOrder = *order;
        *order = this;
    }
    
    inline void
    Assignment::fieldShow() {
        fieldNext->fieldPrev = *this;
        fieldPrev->fieldNext = *this;
    }
    
    inline void
    Assignment::show(Assignment *order) {
        while (order) {
            order->fieldShow();
            order = order->hidingOrder;
        }
    }
    
    inline
    Field::Field(Tile (&tile)[SIDE_2], Row (&row)[SIDE_2], Column (&column)[SIDE_2]) {
        for (size_t value = 0; value < SIDE_2; ++value)
            new Assignment(*this, tile[value], row[value], column[value], value + 1);
    }
    
    inline
    Field::operator size_t() const {
        return value;
    }
    
    inline void
    Field::fieldRecurse(Board &board, size_t level) {
        Assignment    *hiding = nullptr;
    
        for (Assignment *as = next(); *this != as; as = as->next()) {
            as->hide(&hiding);
            value = *as;
            recurse(board, level + 1);
            as->show(hiding);
        }
    }
    
    inline void
    Field::operator delete(void*) {
    }
    
    inline
    Field::~Field() {
        Assignment    *las = prev();
        if (*this != las) {
            for (Assignment    *as = las->prev(); *this != as; as = as->prev()) {
                delete las;
                las = as;
            }
            delete las;
        }
        discard();
    }
    
    inline
    Board::Board() {
        Tile (*const tiles)[SIDE][SIDE_2] = new Tile[SIDE][SIDE][SIDE_2];
        Row (*const rows)[SIDE_2] = new Row[SIDE_2][SIDE_2];
        Column (*const columns)[SIDE_2] = new Column[SIDE_2][SIDE_2];
        
        for (size_t row = 0; row < SIDE_2; ++row) {
            for (size_t column = 0; column < SIDE_2; ++column) {
                new (&fields[row * SIDE_2 + column])
                Field(
                    tiles[row / SIDE][column / SIDE],
                    rows[row],
                    columns[column]
                );
            }
        }
    
        delete[] columns;
        delete[] rows;
        delete[] tiles;
    }
    
    inline Field&
    Board::operator [](size_t idx) {
        return *reinterpret_cast<Field *>(&fields[idx]);
    }
    
    inline
    Board::~Board() {
        for (size_t field = 0; field < SIDE_4; ++field) {
            delete reinterpret_cast<Field *>(&fields[field]);
        }
    }
    
    std::ostream&
    operator <<(std::ostream &stream, const Field &field) {
        stream << (size_t) field;
    
        return stream;
    }
    
    static inline void
    recurse(Board &board, size_t level) {
        if (SIDE_4 == level) {
            for (size_t row = 0; row < SIDE_2; ++row) {
                std::cout
                    << std::setw(FILL - 1) << std::setfill(' ')
                    << board[row * SIDE_2];
                for (size_t column = 1; column < SIDE_2; ++column)
                    std::cout
                        << std::setw(FILL) << std::setfill(' ')
                        << board[row * SIDE_2 + column];
                std::cout << std::endl;
            }
            std::cout << std::endl;
        } else {
            board[level].fieldRecurse(board, level);
        }
    }
    
    int
    main() {
        Board    *board = new Board();
    
        recurse(*board, 0);
        delete board;
        return (0);
    }
    

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.