Memory Limit Exceeded(内存超限)

Memory Limit Exceeded(内存超限)

出现超内存时我们需要对自己的程序的空间复杂度进行优化,此处的空间复杂度是与时间复杂度相对应的。

空间复杂度:

空间复杂度(Space Complexity)是对一个算法在运行过程中临时占用存储空间大小的量度,记做S(n)=O(f(n))。比如直接插入排序时间复杂度是O(n^2),空间复杂度是O(1) 。而一般的递归算法就要有O(n)的空间复杂度了,因为每次递归都要存储返回信息。一个算法的优劣主要从算法的执行时间和所需要占用的存储空间两个方面衡量。      

类似于 [1]  时间复杂度的讨论,它也是问题规模n的函数。

一个算法在计算机存储器上所占用的存储空间,包括存储算法本身所占用的存储空间算法的输入输出数据所占用的存储空间算法在运行过程中临时占用的存储空间这三个方面。

存储算法本身所占用的存储空间:与算法书写的长短成正比,要压缩这方面的存储空间,就必须编写出较短的算法。

算法的输入输出数据所占用的存储空间:是由要解决的问题(问题规模)决定的,是通过参数表由调用函数传递而来的,它不随本算法的不同而改变。

算法在运行过程中临时占用的存储空间:随算法的不同而异。    (来自百度百科)

分析空间复杂度:

算法的空间复杂度一般也以数量级的形式给出。如当一个算法的空间复杂度为一个常量,即不随被处理数据量n的大小而改变时,可表示为O(1);当一个算法的空间复杂度与以2为底的n的对数成正比时,可表示为O(log2n);当一个算法的空间复杂度与n成线性比例关系时,可表示为O(n).若形参为数组,则只需要为它分配一个存储由实参传送来的一个地址指针的空间,即一个机器字长空间;若形参为引用方式,则也只需要为其分配存储一个地址的空间,用它来存储对应实参变量的地址,以便由系统自动引用实参变量。        (来自百度百科)

避免的方法:

只能是跟据题目所给出的数据范围,看一看数组开辟的能不能再小一些,或者更改算法以使用更小的内存。

 

其它莫名导致MLE的题:

1.     做字典树,AC自动机

        把存树结点的数组,在init()初始化函数中一次性清零。MLE。。。

        

    void init()  //初始化
    {
        while(!qu.empty())
            qu.pop();
        mem(ne, 0);     //所用数组一次性清零
        mem(fail,0);
        mem(vis,0);
        mem(book,0);
         tot=1;
    }

    void Insert(char *str,int y)  //插入字符串
    {
        int ls=strlen(str);
        int rt=0;
        for(int i=0; i<ls; i++)
        {
            int x=str[i];   //把字符串的字符存入字典树
            if(!ne[rt][x])
                ne[rt][x]=tot++;  //若这一字符没有在这一分支 ,节点数+1;
            rt=ne[rt][x];
        }
        vis[rt]=y+1;
        //   printf("stateT_cnt==%d\n",stateT[rt].cnt);
    }

        要在建树的时候一个一个清零。。。 就是要保证只清零了要用的点; AC

       

void init()  //初始化
    {
        while(!qu.empty())
            qu.pop();
        mem(ne[0], 0);   //
        fail[0]=-1;
        tot=1;
    }

    void Insert(char *str,int y)  //插入字符串
    {
        int ls=strlen(str);
        int rt=0;
        for(int i=0; i<ls; i++)
        {
            int x=str[i];   //把字符串的字符存入字典树
            if(!ne[rt][x])
            {
                mem(ne[tot],0);   //建树时清零,保证要用的数据点清零
                fail[tot]=-1;
                ne[rt][x]=tot++;  //若这一字符没有在这一分支 ,节点数+1;
            }
            rt=ne[rt][x];
        }
        vis[rt]=y;
        //   printf("stateT_cnt==%d\n",stateT[rt].cnt);
    }

2. 数学题  (Smith Numbers)

vector<int>ve;     在get_s函数里可以调用gt_n函数;  没调用get_n函数直接在get_s函数又写一遍,结果MLE

ll get_n(ll x)
{
    ll ans=0;
    while(x)
    {
        ans += x%10;
        x/=10;
    }
    return ans;
}
ll get_s(ll x)
{
    ll ans=0;
    prime_decompose(x);
    for(ll i=0;i<ve.size();i++)
    {
       // printf("ve%d ",ve[i]);
        while(ve[i])
        {
            ans += ve[i]%10;
            ve[i] /= 10;
        }
    }
    return ans;
}

调用了的,AC

ll get_n(ll x)
{
    ll ans=0;
    while(x)
    {
        ans += x%10;
        x/=10;
    }
    return ans;
}
ll get_s(ll x)
{
    ll ans=0;
    prime_decompose(x);
    for(ll i=0;i<ve.size();i++)
    {
       ans+=get_n((ll)ve[i]);   //直接调用
    }
    return ans;
}

 

  • 24
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您好,"gee user memory limit exceeded" 表示您的计算机或服务器的内存限制已超出。这可能是由于您正在运行的程序或应用程序使用了太多的内存,导致系统无法处理更多的数据。您可以尝试关闭一些程序或应用程序,或增加计算机或服务器的内存容量来解决此问题。 ### 回答2: 当我们在使用电脑或其他设备时,会偶尔遇到一些类似于“Gee user memory limit exceeded”的提示信息。这个提示信息通常是出现在我们的设备中的物理内存(RAM)已经不能继续为我们所要求的程序提供额外的空间时。 首先,需要了解的是,内存是电脑中进行操作的一个非常重要的组件。在我们的电脑或其他设备中,内存有一个物理限制,也就是说,我们不能无限制地往电脑里添加内存容量。一旦内存容量达到了极限,我们就需要清空或释放一些空间才能继续操作设备了。 当我们的程序或操作请求超过设备中存在的物理内存容量时,就会出现类似于“Gee user memory limit exceeded”的提示信息。这种情况往往发生在电脑或手机过于老旧,内存容量较小的时候,因为这时设备本身的物理限制就存在,往往会导致内存不足的情况。 为了避免这种情况发生,我们可以采取一些措施,如升级设备内存、关闭一些多余的程序或应用,或者使用一些清理软件,清理设备内部的垃圾文件。此外,我们也可以尝试使用一些较轻量级的软件或程序,减少设备内存的占用情况。总之,遇到“Gee user memory limit exceeded”的提示信息时,我们需要适当地优化和调整我们的设备使用,同时保持设备的硬件配置在适当的范围内,以避免影响我们的使用体验。 ### 回答3: “gee user memory limit exceeded”是指在使用Google Earth Engine (GEE)时,用户在计算时达到了内存的使用上限,导致GEE无法继续计算并显示这个错误提示。 GEE是一个大规模地理空间数据处理平台,可以在云端运行,提供了强大的地理空间数据处理和分析能力。但是,在处理数据时需要使用一定的计算资源(包括内存),如果用户的数据量太大或计算复杂度太高,很容易超出GEE的内存限制。 为了避免出现“gee user memory limit exceeded”错误,用户可以采取以下措施: 1.尽可能使用更小的数据集。如果数据太大,可以考虑将其从云端下载至本地进行处理,或者通过裁剪、筛选等方式缩小数据量。 2.优化代码逻辑,避免不必要的计算和变量保存。例如,在处理时可以先筛选一部分数据进行计算,然后保存结果并释放变量,接着再处理下一部分数据。 3.在处理前检查计算资源。可以使用GEE提供的SystemStats功能来查看当前可用的内存和CPU资源,以避免出现不必要的浪费。 总之,“gee user memory limit exceeded”错误是GEE中常见的问题之一,但通过优化数据处理方式和代码逻辑,用户可以有效避免。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值