在计算机的存储系统中,最基本的存储单位是字节(Byte,简写为B),
例如:存储名词ZheJiang,会占用8个字节(即:8B),而存储学号2019019999,会占用10个字节(即:10B)
当存储容量较大时,为了描述方便,也可以使用更大的存储单位,如:千字节(Kilobyte,简写为KB或K)、兆字节(Megabyte,简写为MB或M)
其中,1K=210B=1024B,即:1024个字节
1M=210K=1024K=1024×1024B=1048576B,即:1048576个字节
- 要求:根据输入的存储容量,计算占用多少个字节。
输入格式:
- 存储容量,格式为:整数N(1≤N≤1024),以及单位后缀(B、K、M,其中:B可以省略)
输出格式:
- 占用了多少个字节(无后缀)
输入样例:
128B
128
2K
1024M
输出样例:
128
128
2048
1073741824
Solution:
#include<stdio.h>
int main()
{
int i,k,n=0;
char s[1000];
gets(s);
k=strlen(s);
if(s[k-1]>='0'&&s[k-1]<='9'){
for(i=0;i<k;i++) n=n*10+s[i]-'0'; //ASCII码转整型
printf("%d\n",n);
}
else if(s[k-1]=='B'){
for(i=0;i<k-1;i++) n=n*10+s[i]-'0'; //-'0'!!!
printf("%d\n",n);
}
else if(s[k-1]=='K'){
for(i=0;i<k-1;i++) n=n*10+s[i]-'0';
n=n*1024;
printf("%d\n",n);
}
else if(s[k-1]=='M'){
for(i=0;i<k-1;i++) n=n*10+s[i]-'0';
n=n*1024*1024;
printf("%d\n",n);
}
return 0;
}