我是靠谱客的博主 落后外套,最近开发中收集的这篇文章主要介绍读取访问权限冲突:_Pnext是 0x8,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

猜测是内存问题

原来代码:

p[100],q[100],r0[200];

问题描述:测试长度大概小于50时是没问题的,靠近100就不行了,而且会报错**_Pnext** 是 0x8

解决方案:

using namespace std;
int p[350], q[350], r0[500];
string s1, s2;
int n;
// int_multifly.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int p[350], q[350], r0[500];
string s1, s2;
int n;
/// <summary>
/// 
/// 整数求和
/// </summary>
void d_add(int p[], int q[], int c[], int  n)
{
	int i, c1 = 0;
	for (i = n - 1; i >= 0; i--)
	{
		c[i] = p[i] + q[i] + c1;
		if (c[i] >= 10 && i > 0)
		{
			c[i] = c[i] - 10;
			c1 = 1;
		}
		else
		{
			c1 = 0;
		}
	}
}
/// <summary>
/// 当系数只有两项时,直接计算乘积
/// </summary>
void d_product(int p[], int q[], int c[])
{
	int t1, t2, r[4] = { 0,0,0,0 };
	t1 = p[0] * q[0];
	c[1] = t1 % 10;
	c[0] = t1 / 10;
	t2 = p[1] * q[1];
	c[3] = t2 % 10;
	c[2] = t2 / 10;
	r[1] = (p[0] + p[1]) * (q[0] + q[1]) - t1 - t2;
	r[2] = r[1] % 10;
	r[1] = r[1] / 10;
	d_add(c, r, c, 4);
}

把全局变量p,q,r0的长度调大了两倍之后,发现对于n<=100都没有问题了

希望能解决你的问题,也希望这个问题大家做一个理论解释!

最后

以上就是落后外套为你收集整理的读取访问权限冲突:_Pnext是 0x8的全部内容,希望文章能够帮你解决读取访问权限冲突:_Pnext是 0x8所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(39)

评论列表共有 0 条评论

立即
投稿
返回
顶部