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


C++ Struct::remove方法代码示例

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


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

示例1: start

void start() {
    int number(1);
    Struct *head = new Struct();
    Struct *temp;
    cout << "Start X : ";
    cin >> head->x;
    cout << "Start Y : ";
    cin >> head->y;
    head->next = NULL;

    horse->path[head->x][head->y] = number++;
    horse->mark[head->x][head->y] = 0;
    
    while (number <= (SIZE * SIZE)) {

        if (number == (SIZE * SIZE)) {                      //最后一步单独处理
            for (int i(0);i < SIZE;i++) {
                for (int j(0);j < SIZE;j++) {
                    if (horse->mark[i][j] == 1) {
                        head = head->add(i, j, head, 0);
                        horse->path[i][j] = number++;               
                        horse->mark[i][j] = 0; 
                        break;
                    }
                }
            }
            continue;
        }
        
        horse->init();                                          //初始化权值表
        horse->updateWeight(head->x, head->y);                  //更新这一点的权值表

        if (flag) {
            horse->weight[temp->key] == SIZE + 1;
        }

        int key = horse->findSmall();                           //找到权值最小的点

        if (key == -1 && number != (SIZE * SIZE + 1)) {
            horse->mark[head->x][head->y] == 1;
            horse->path[head->x][head->y] == 0;
            number--;
            temp = head;
            head = head->remove(head);
            flag = true;
            continue;
        }

        x = head->x;
        y = head->y;
        getXY(key);                                                 //得到该点对应的坐标
        head = head->add(x, y, head, key);                           //将新走的位置坐标插入链表
//        cout << head->x << " , " << head->y << "     " << number << endl;
        horse->path[head->x][head->y] = number++;
        horse->mark[head->x][head->y] = 0;                     //标记为已走过 
    }
   print();
}
开发者ID:normalJaylan,项目名称:CPP-Programs,代码行数:58,代码来源:start.cpp


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