ACMSTEP 1.2.4 ecimal System //水题 模拟 活用Sprintf和sscanf
来源:互联网 发布:孔令仪 知乎 编辑:程序博客网 时间:2024/06/05 11:48
decimal system
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 718 Accepted Submission(s): 312Problem Description
As we know , we always use the decimal system in our common life, even using the computer. If we want to calculate the value that 3 plus 9, we just import 3 and 9.after calculation of computer, we will get the result of 12.
But after learning <<The Principle Of Computer>>,we know that the computer will do the calculation as the following steps:
1 computer change the 3 into binary formality like 11;
2 computer change the 9 into binary formality like 1001;
3 computer plus the two number and get the result 1100;
4 computer change the result into decimal formality like 12;
5 computer export the result;
In the computer system there are other formalities to deal with the number such as hexadecimal. Now I will give several number with a kind of change method, for example, if I give you 1011(2), it means 1011 is a number in the binary system, and 123(10) means 123 if a number in the decimal system. Now I will give you some numbers with any kind of system, you guys should tell me the sum of the number in the decimal system.
But after learning <<The Principle Of Computer>>,we know that the computer will do the calculation as the following steps:
1 computer change the 3 into binary formality like 11;
2 computer change the 9 into binary formality like 1001;
3 computer plus the two number and get the result 1100;
4 computer change the result into decimal formality like 12;
5 computer export the result;
In the computer system there are other formalities to deal with the number such as hexadecimal. Now I will give several number with a kind of change method, for example, if I give you 1011(2), it means 1011 is a number in the binary system, and 123(10) means 123 if a number in the decimal system. Now I will give you some numbers with any kind of system, you guys should tell me the sum of the number in the decimal system.
Input
There will be several cases. The first line of each case contains one integers N, and N means there will be N numbers to import, then there will be N numbers at the next N lines, each line contains a number with such form : X1….Xn.(Y), and 0<=Xi<Y, 1<Y<=10. I promise you that the sum will not exceed the 100000000, and there will be at most 100 cases and the 0<N<=1000.
Output
There is only one line output case for each input case, which is the sum of all the number. The sum must be expressed using the decimal system.
Sample Input
31(2)2(3)3(4)411(10)11(2)11(3)11(4)
Sample Output
623
我真想不到 如果不用sscanf和sprintf这道题应该怎么做。
不过还是很简单的。任意进制转换十进制的方法也要会。
还要注意:比赛中不应该用Atoi这套函数 因为不是ANSI C的标准库函数。。
#include <iostream>#include <cstdio>#include <cstring>#include <cmath>#include <cstdlib>using namespace std;long change(int n, int bases){long i, temp = 0, len;char ex[30];sprintf(ex,"%d",n);len = strlen(ex);for (i = 0; i<len; i++){temp+= (ex[i]-'0') * (long)pow((double)bases,(double)len-1-i);}return temp;}int main(){//freopen("c:\\in.txt","r",stdin);int i, cases, j, sum, b, nums;char str[30];while(cin>>cases){sum = 0;for (i=0; i<cases; i++){cin>>str;sscanf(str,"%d(%d)",&nums,&b);sum += change(nums, b);}cout<<sum<<endl;}return 0;}
- ACMSTEP 1.2.4 ecimal System //水题 模拟 活用Sprintf和sscanf
- sscanf和sprintf
- sscanf 和 sprintf
- sscanf和sprintf
- sscanf和sprintf
- sscanf 和sprintf 函数
- sprintf和sscanf
- sscanf和sprintf使用
- sprintf() 和 sscanf()
- Sprintf 和 sscanf
- sscanf和sprintf
- sprintf和sscanf
- sprintf和sscanf详解
- sscanf和sprintf
- sscanf() 和 sprintf() 函数
- sprintf和sscanf总结
- sprintf和sscanf
- sscanf和sprintf
- ASP.NET Application,Session,Cookie和ViewState等对象用法和区别
- fvwm-crystal 中文标题显示设置
- 图形闪烁
- 感谢你,我衷心的谢谢你!
- mfc绘图的简介与内容
- ACMSTEP 1.2.4 ecimal System //水题 模拟 活用Sprintf和sscanf
- 《大话处理器》连载——微架构(5) DSP更深的流水线
- oracle 中的分页查询语句
- HttpWebResponse请求时间太长(10秒左右)
- 单源最短路径问题[Dijkstra实现]
- SQL语句大全
- 《c程序设计语言》 1.2变量及算术表达式
- 什么是java的path和classpath?
- Linux下TFTP SERVER配置