‘壹’ 使用c语言,如何防止输入整型数据位数为1000的数据溢出
这么长的数据基本上已经超过所有的数据类型了。
我觉得只能按照字符串处理,第一足够大的字符串数组,然后根据进行存储。
‘贰’ 为防止溢出,C语言中应该如何定义变量
分类: 电脑/网络 >> 程序设计 >> 其他编程语言
问题描述:
我求的是阶乘有LONG是没用的
解析:
给你个求阶乘的小程序,只要最大结果位数不超过20000就行。这种超大规模的阶乘是不能用简单的long保存的。位数太大了。
#define M 20000 /* 最大结果位数,DOS能访问的内存有限,最好不要超过 30000 位*/
#define N (M+5)
main()
{
int Num;
register int i,j,k,flag;
register unsigned int n,m,pc;
unsigned char str_n[5],result_0[N],result_1[N];
void fun_print_result(char *result,int flag);
int fun_mul(char *a,char *b,char *c,int flag);
printf("输入计算其阶乘的数:Num = ");
scanf("%d",&Num);
if(Num >= 100)
{
printf("\n正在进行阶乘运算. . .\n");
printf("已完成 00000 的阶乘,请等待. . .");
}
for (j=0;j<N;j++)
{
result_1[j] = 0; result_0[j] = 0;
}
result_1[N-1] = 1;
for(i=0;i<5;i++)
{
str_n[i] = 0;
}
n = 1;
pc = 0; flag = N-1;
while (n <= Num)
{
m = n;
k = 4;
while(m > 0)
{
str_n[k] = m%10; m /= 10; k--;
}
if (pc%2 == 0)
{
if(fun_mul (str_n,result_1,result_0,flag) != 1)
{
printf("\n\n结果溢出!当前所设置的最大结果为 %d 位 已完成 %d 的阶乘",M,pc);
exit(0);
}
}
else
{
if(fun_mul (str_n,result_0,result_1,flag) != 1)
{
printf("\n\n结果溢出!当前所设置的最大结果为 %d 位 已完成 %d 的阶乘",M,pc);
exit(0);
}
}
flag = flag-(4-k); /* flag 标记相乘后“可能的”第一个有效数字的标号 */
if(pc%2 == 0) /* 再处理一次使 flag 正好标记第一个有效数字的标号 */
{
if(result_0[flag] == 0) flag++;
}
else
{
if(result_1[flag] == 0) flag++;
}
n++; pc++;
if((pc)%25 == 0 && Num >= 100 && pc >= 100)
{
printf("\r已完成 %5d",pc);
}
}
if(Num >= 100) printf("\n");
if ((pc-1)%2 == 0)
{
fun_print_result (result_0,flag);
}
else
{
fun_print_result (result_1,flag);
}
}
int fun_mul(char *a,char *b,char *c,int flag) /* 相乘函数 */
{
register int i,j;
for(j=flag;j<N;j++) c[j]=0;
for(i=4;i>=0;i--)
{
if(a)
{
for (j=N-1;j>=flag;j--)
{
if(b[j])
{
c[i+j-4] += a[i]*b[j];
}
if(c[i+j-4] > 9)
{
c[i+j-5] += c[i+j-4]/10; c[i+j-4] %= 10;
}
}
}
}
if(flag < 10)
{
if (c[0] || c[1] || c[2] || c[3] || c[4]) /*** 结果溢出判断 ***/
{
return 0;
}
}
return 1;
}
void fun_print_result(char *result,int flag) /* 输出结果函数 */
{
int p;
printf("\n本次计算结果共有 %d 位,如下:\n\n",N-flag);
for(p=flag;p<N-1;p++)
{
printf("%d",result[p]);
if((p+1-flag)%(21*80) == 0)
{
printf("\n计算结果太长,请按任一键看下一屏,Esc 退出");
if(getch() == 27)
{
clrscr(); exit(0);
}
clrscr();
}
}
printf("%d",result[N-1]);
printf("\n\n[OK]");
}
‘叁’ c语言中数据溢出的问题怎么解决
需要准备的材料分别有:电脑、C语言编译器。
1、首先,打开C语言编译器,新建一个初始.cpp文件,例如:test.cpp,输入问题基础代码。
‘肆’ 请教C语言高手,你们是如何防止数据计算溢出的
根据数据类型和计算结果范围,选择合适的数据类型。
另外一种方式就是对输入数据进行限定,保证运算不会出现越界的可能。
还有一些其它复杂的计算方式,这里就不给你做介绍了
‘伍’ C语言中为了避免缓冲区溢出应尽量使用哪些函数
缓冲区溢出是因为
使用了全局变量或者分配内存
然后这些东西占用了电脑内存,一旦使用的内存太于在电脑可运行的分配内存就会产生溢出。
所以你要解决这个问题写代码要注意2点
1、少使用Const变量,在函数里使用变量(函数使用完变量会自动释放)
2、分配内存后,就比如你new了一个对象,如果不使用这个对象的话就要Delete
(不同分配内存的东西,释放方法不一样,具体根据你分配内存的方法,网络一下就能找
到释放方法)
‘陆’ C语言中在阶乘的程序中如何避免中间结果溢出
使用数组吧,数组的地址是连续的,所以你只需加个判断就可以了,当地位溢出时,高位自动加一的操作,最后想输出结果,那就遍历数组的所以位数,求出来就可以了
‘柒’ 在c语言中如果输入数据太大,该怎么避免
C语言的输入输出比较原始,要看是如何进行输入的:
1,从控制台输入
这里其实输入的都是终端的字节流,控制字节流就可以达到控制输入数据的目的
2,从其他输入设备输入
例如,从文件读取,那么就要在程序里读取合适大小的数据段,避免出现溢出的现象。
‘捌’ c语言数据溢出怎么办
C语言的强大之处就在于他的灵活性,程序员自己把握。编译器可以帮助预防错误,但有些程序会利用溢出,所以溢出不完全是错误的事情。
1、溢出:
数据类型超过了计算机字长的界限而出现的数据溢出;
2、溢出可能原因:
当应用程序读取用户数据,复制到应用程序开辟的内存缓冲区中,却无法保证缓冲区的空间足够时 (假设定义数组int Array[10], 而在调用时使用Array[11] 或存放的数据超过int类型容量等), 内存缓冲区就可能会溢出.
3、溢出因素分析:
由于C/C++语言所固有的缺陷,既不检查数组边界,又不检查类型可靠性,且用C/C++语言开发的程序由于目标代码非常接近机器内核,因而能够直接访问内存和寄存器,只要合理编码,C/C++应用程序在执行效率上必然优于其它高级语言。然而,C/C++语言导致内存溢出问题的可能性也要大许多。
‘玖’ 在c语言编程中,如何避免整数运算溢出问题
C语言编译时不会检查数据溢出问题,需要编程者自行注意数据溢出问题。而且据我的经验数据溢出问题会频繁出现在初学习当中,程序写多了就很少出现这样的问题了。