C语言中如果所需输入的数字太长用LONG不够怎么办
可以用long类型,在不够就用double储存整型数,要是还不够就用字符串(字符数组)存。定义一个char str[1000],就能存1000位了。
你可以试试 long long 8字节的。你也可以用int64_t什么的。如果实在是太大了,那么你就把它保存到数组中来处理吧。
如果你用的编译器是gcc,可以用long long类型,范围是2的64次方。如果是用VC,可以用__int64 ,范围是2的64次方。
数据不太多的话可以试试将18位的数据分成两段,第一段用int,取后两位;第二段用long,用全部。这样做得话就是操作起来比较麻烦。。
long,double可以存储比较大的数,但是有效数字并没有比long高多少只是在后面加上了*10^n。如果你要的是精确的记录,建议用字符数组如char integer[200];要计算的话有点复杂,需要自己定义函数或数据结构。
这类数列的问题必然是用整数来做,用浮点数的思路显然是有问题的。超长整数没有太好的办法,只有自己写算法实现超长整数的运算。或许有现成的第三方库支持超长整数的运算,但我不知道,呵呵。
c语言:用字符串表示超长整数的运算
scanf(%s, num2);add(num1, num2, result);printf(两个整数的和为:%s\n, result);return 0;} 在上面的代码中,reverse函数用于将一个字符串反转。
自定义一个不限定长度的字符串输入函数,在主函数中调用输入数字字符串后求字符串各元素代表的十进制数字之和。
把for(i=len-1;i=0;i–)改成for(i=len-1;i=0;i–)。把x+=n*p[i];改成x+=n*(p[i]-0);。最好把gets(s);改成scanf(%s,s);。
{ b=b*10+a%10; a=a/10; n++; } printf(%d位数,%ld,n,b);}已经运行过,有问题请留言。不必使用字符串,上面就是例子。当然也可以使用字符串。个人感觉使用字符串反而麻烦一些。
回答:这个超大数不是10的100次方个数,而是一个数,那么我们会用一个整型的数据存储,但没有相应的整型类型能存放这么大的数。
根据提示,明显并不是用字符型数组去计算,可以先用长整型数去计算,分别把高位和低位存放在两个长整型变量咯,计算得到最终结果后再存入字符型数组!貌似这和2012年全国软件大赛中一题的题目类似。大赛题目中,只算乘法。
C语言计算问题
输出是2080——由于*=的优先级比+低,所以x+=3+2;就是x*=(3+2);也就是x+=5;,所以第一个printf(%d,x);输出20。
sp函数参数int *a是一个地址。所以sp(&k),这里把变量k的地址传递到函数sp中,保存在sp指针a中。所以sp对k地址操作,就会改变k的值。
C语言或者所有计算机语言中,浮点数都有精度的问题 也就是说,当你输入的是0.2 打印出来的可能也是0.2 但实际上它是近似的 你这个程序就遇到了这样的一个问题了。
C语言的表达式计算确实让人头大,因为C语言程序就是表达式组成的,而运算符又特别多,特别复杂。具体这个问题,%与/优先级一样,所以从左边运算,17%4结果是1,1/8结果是0,这里参与运算的都是整数,结果也只能是整数。
没办法,100!阶乘和数据是在太大,造成变量溢出了,溢出后内容连符号位都冲掉了。
C语言中,我已经申请了一个数组,可是后来发现长度不够,有什么办法加长啊…
不可以,数组的长度必须是固定的,不能从外边输入一个数来控制数组的长度,用指针也不行,c语言不支持这样的语句,系统会自动检测为错误。
原理就是,用整个数组的字节数除以一个元素的字节数,结果就是数组的长度。
我从没这样弄过。 你需要的是一个未知长度的 数组 ,所以不给这个数组赋值就是最好的。
c语言是高级语言,定义数组的指令会转换成分配内存的指令,至于有没有为这块内存初始化,则是取决于编译器的实现。你这个实验做得很好,可以通过你这个实验了解到编译器是如何实现的。