电光小子 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 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥30 python代码,帮调试,帮帮忙吧