当前位置: 首页>>代码示例>>C++>>正文


C++ Puzzle::setCellNumber方法代码示例

本文整理汇总了C++中Puzzle::setCellNumber方法的典型用法代码示例。如果您正苦于以下问题:C++ Puzzle::setCellNumber方法的具体用法?C++ Puzzle::setCellNumber怎么用?C++ Puzzle::setCellNumber使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Puzzle的用法示例。


在下文中一共展示了Puzzle::setCellNumber方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: guess

//return true if guess was correct
bool guess(Puzzle &puzzle, Puzzle &alternative)
{
    for (int i = 0; i < 9; ++i)
    {
        for (int j = 0; j < 9; ++j)
        {
            if ((puzzle.getCellNumber(i, j) == 0) && !(puzzle.getPossibleValues(i, j).empty()))
            {
                for (int k = 0; k < puzzle.getPossibleValues(i, j).size(); ++k)
                {
                    //make an alternative puzzle that assumes the puzzle is false
                    //MUST MAKE A DEEP COPY
                    alternative.erasePossibleValue(i, j, puzzle.getPossibleValues(i, j)[k]);
                    
                    //set number as guess
                    puzzle.setCellNumber(i, j, puzzle.getPossibleValues(i, j)[k]);
                    puzzle.getPossibleValues(i, j).clear(); //clear possible values after setting cell number
                    puzzle.updateRowColumnRegion(i, j);
                    return true;
                }
            }
            else if (puzzle.getCellNumber(i, j) == 0 && puzzle.getPossibleValues(i, j).empty())
                return false;
            //contradiction occured...
        }
    }
    return 0;
} //must return false for contradictions
开发者ID:zbr19583,项目名称:SudokuSolver,代码行数:29,代码来源:main.cpp

示例2: hiddenSingles

bool hiddenSingles(Puzzle &puzzle)
{
    for (int i = 0; i < 9; ++i)
        for (int j = 0; j < 9; ++j)
            if (puzzle.getCellNumber(i, j) == 0)
            {
                for (int k = 0; k < puzzle.getPossibleValues(i, j).size(); ++k)
                {
                    if (!puzzle.posInRegion(i, j, puzzle.getPossibleValues(i, j)[k]) || !puzzle.posInColumn(i, j, puzzle.getPossibleValues(i, j)[k]) || !puzzle.posInRow(i, j, puzzle.getPossibleValues(i, j)[k]))
                    {
                        puzzle.setCellNumber(i, j, puzzle.getPossibleValues(i, j)[k]);
                        puzzle.getPossibleValues(i, j).clear();
                        puzzle.updateRowColumnRegion(i, j);
                        return true;
                    }
                }
            }
    return false;
}
开发者ID:zbr19583,项目名称:SudokuSolver,代码行数:19,代码来源:main.cpp


注:本文中的Puzzle::setCellNumber方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。