电光小子 2019-03-17 20:21 采纳率: 0%
浏览 775

c++的memset()函数初始化为-1比0更快

#include<iostream>
#include<string.h>
using namespace std;
int main(){
        int m, n;
            cin >> m >> n;
            int matrix[200][200];
            memset(matrix, -1, sizeof(matrix));
            int a = 0, b = 0;
            for ( a = 0; a < m; a++) {
                for (b = 0; b < n; b++) {
                    cin >> matrix[a][b];
                }
            }

             a = 0, b = 0;
            int count = 0;//
            while (count < m * n) {
                //下 
                while (a < m && matrix[a][b] != -1) {
                    cout << matrix[a][b] << " ";
                    matrix[a][b] = -1;//标记已经选过的
                    a++;
                    count++;
                }
                b++;//如果不满足条件,跳出循环,转向
                a--;//修正a
                    //右
                while (b < n && matrix[a][b] != -1){
                    cout << matrix[a][b] << " ";
                    matrix[a][b] = -1;
                    b++;
                    count++;

                }
                a--;
                b--;
                while (a >= 0 && matrix[a][b] != -1) {
                    cout << matrix[a][b] << " ";
                    matrix[a][b] = -1;
                    a--;
                    count++;

                }
                b--;
                a++;
                while (b >= 0 && matrix[a][b] != -1) {
                    cout << matrix[a][b] << " ";
                    matrix[a][b]  = -1;
                    b--;
                    count++;    

                }
                a++;
                b++;
            }
            return 0;
        }

这个算法,我如果把它初始化为0,判断条件也改为0,然后就会报超时错误。有点想不通,难道初始化为-1比0更快?

  • 写回答

2条回答 默认 最新

  • threenewbee 2019-03-17 23:57
    关注

    int matrix[200][200];
    在堆栈上开辟那么大空间,效率比较低,这个要看cpu缓存。

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器