NYOJ 112 指数运算

由于是pow函数返回的是浮点型,此处不行,考虑到long long int 

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 int main()
 4 {
 5     int x,n,i;
 6     long long int s;
 7     while(scanf("%d%d",&x,&n)!=EOF)
 8     {
 9         s=1;
10         for(i=0;i<n;i++)
11         {
12             s=s*x;
13         }
14         printf("%lld\n",s);
15     }
16     system("pause");
17     return 0;
18 }

 

 

1:long long int 的使用:

今天在九度的网上评测系统刷华科的往年的机试题,遇到了大数处理的问题,也就是超过了一般的int,其解决办法一般是:一、可以用字符串处理,可是有些题开始输入为字符串,可是结果要输出数字型的,所以有时用字符串也挺麻烦的!第二种方法:所以有时也得用点长长整形,即long long int,其实简单书就是定义为long long int,然后输出时页和其他不同,经过我的测试定义为long long int,输出时必为printf("%lld",a),a为定义的long long int的变量。其他的我就没测试了,不过上述方法绝对正确!!!不过还有一个限制就是上述方法好像必须在linux下用gcc进行编译才可以。有其他方法欢迎补充!!!集思广益嘛:

2:前言:

  在16位环境下,int/unsigned int 占16位,long/unsigned long占32位
  在32位环境下,int占32位,unsigned int占16位,long/unsigned long占32位
何时需要使用
  long 和 int 范围是[-2^31,2^31),即-2147483648~2147483647,而unsigned范围是[0,2^32),即0~4294967295,所以常规的32位整数只能够处理40亿左右,
遇到比40亿大的多的数就要用到64位
64位使用范围:
  不 同的编译器对64位整数的扩展有所不同,VC使用__int64/unsigned __int64,范围是[-2^63, 2^63)和[0,2^64),即-9223372036854775808~9223372036854775807与 0~18446744073709551615(约1800亿亿)。

注意点:
1、编译器不同导致使用64位的申明方式不同;
2、long long / unsigned long long 一般是Linux下申明方式、如:G++
3、__int64 /unsigned __int64一般是Windows下使用64位的申明方式,如:VS
4、在赋值时需要注意加上ll进行显式赋值;
5、当进行64位与 32位的混合运算时,32位整数会被隐式转换成64位整数。
6、输出printf("");,long long使用%lld输出,__int64使用%I64d,无符号使用u替代d即可。
7、测试下来编译器一般都支持2种操作,不必太过纠结,怎么使用看个人喜欢。

//=================================华丽的分隔线========================================
#include <stdio.h>
#include <stdlib.h>
intmain(){
    unsigned long longa= 412432424000ll;
    unsigned __int64b= 9223372036854775808ll;
    printf("%I64u\n",a);                 //使用%lld时无法正常输出,why? 解答在附
    printf("%I64u",b);
    system("pause");
    return 0;
}
附网友测试结果:
  刚实验了下,在VC6、DEV、CodeBlocks中C语言都可以使用__int64,格式化输出标识为%I64d。不过在VC6中数字后加2个L是会报错,可以只加1个或不加。查了下资料,__int64是windows专用的,被vc、gcc等编译器支持,但在在UNIX、Linux中需用long long配合%lld。后者是标准C的规定!
  我试了下long long配合%I64d,可以正确输出,而不管是long long还是__int64配合%lld都不能正确输出。所以我得出的结论是在windows下需要用longlong或,__int64配合dd。而在UNIX、Linux中必须使用标准C规定的long long配合%lld。

int main()
{
__int64 i = 10;
printf("%l64",i);
cout<<endl;
return 0;
}
cout<<i;// has problems
 
3:int ,long, long long取值范围

unsigned   int   0~4294967295   
int   2147483648~2147483647 
unsigned long 0~4294967295
long   2147483648~2147483647
long long的最大值:9223372036854775807
long long的最小值:-9223372036854775808
unsigned long long的最大值:1844674407370955161

__int64的最大值:9223372036854775807
__int64的最小值:-9223372036854775808
unsigned __int64的最大值:18446744073709551615

posted on 2012-08-07 10:40  mycapple  阅读(268)  评论(0编辑  收藏  举报

导航