梧桐下的四叶草 2015-05-14 07:28 采纳率: 33.3%
浏览 1838
已采纳

下面的代码数组不是越界了吗??为什么还可以运行而且不报错??

dp【j-1】这里当j==0时为什么不报错??
#include
#include
#include
using namespace std;
char str[1010];
int dp[1010];
bool judge(int x,int y) //判断是不是回文串
{
while(x <= y)
{
if(str[x] != str[y])
return false;
x++;
y--;
}
return true;
}
int main()
{
int len, i, j;
while(gets(str) != NULL)
{
len = strlen(str);
for(i = 0; i < len; i++)
{
dp[i] = i + 1; //假设前面的都不能组成回文串
for(j = 0; j <= i; j++)
if(str[j] == str[i] && judge(j,i))
dp[i] = min(dp[i], dp[j-1]+1);
}
printf("%d\n",dp[len-1]);
}
return 0;
}

  • 写回答

6条回答 默认 最新

  • LemonSmile_ 2015-05-14 09:09
    关注

    C++语言中数组越界访问系统不会给出任何的提示,程序员可以超出数组边界进行读/写从而造成内存的混乱,而这种错误对初学者来说是很容易出现的、而又偏偏是很难调试的,因为系统不会给出错误的提示,所以就这样使用数组是不安全的。
    http://blog.sina.com.cn/s/blog_60e96a410100lpqt.html

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • 小嵌的linux之路 2015-05-14 07:37
    关注

    gdb调试一下,看一下dp【j-1】的内容

    评论
  • threenewbee 2015-05-14 07:37
    关注

    C++出于性能的考虑不会对越界进行检查,所以代码可能能运行可能不能。因为数组之后可能会有些内存不使用。当然这给调试程序带来困难。程序的错误很难发现。谁让你用C++呢,如果一不小心那就活该倒霉了。

    评论
  • Eleven 2015-05-14 08:02
    关注

    C++不检查数组越界的错误,这个是程序员的责任。

    评论
  • jeason29 2015-05-14 09:25
    关注
    越界这事可大可小,如果刚好你越界的那个地址是一个很重要的数据,那么后果可想而知,但是C/C++不会对越界给出提示,只要有空间它就会写
    
    评论
  • lf00zero 2015-05-21 07:05
    关注

    C++语言中数组越界访问系统不会给出任何的提示,程序员可以超出数组边界进行读/写从而造成内存的混乱,而这种错误对初学者来说是很容易出现的、而又偏偏是很难调试的,因为系统不会给出错误的提示,所以就这样使用数组是不安全的。

    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 网络打印机Ip地址自动获取出现问题
  • ¥15 求局部放电案例库,用于预测局部放电类型
  • ¥100 QT Open62541
  • ¥15 stata合并季度数据和日度数据
  • ¥15 谁能提供rabbitmq,erlang,socat压缩包,记住版本要对应
  • ¥15 Vue3 中使用 `vue-router` 只能跳转到主页面?
  • ¥15 用QT,进行QGIS二次开发,如何在添加栅格图层时,将黑白的矢量图渲染成彩色
  • ¥50 监控摄像头 乐橙和家亲版 保存sd卡的文件怎么打开?视频怎么播放?
  • ¥15 Python的Py-QT扩展库开发GUI
  • ¥60 提问一下周期性信信号的问题