UVA - 10106 Product 第二种解法
来源:互联网 发布:linux下退出vi 编辑:程序博客网 时间:2024/06/06 07:46
题目大意:求两个数的成积
解题思路:分步解决,一个个相乘再相加
#include<cstdio>#include<cstring>void add(char *sum, char * num2,int len) {int i;for( i = 0 ; i < len; i++) {int num = sum[i] + num2[i] - '0';sum[i] = num % 10;if(num > 9)sum[i+1] = sum[i+1] + 1;}}int main() {char num1[1000];char num2[1000];while( gets(num1)) {gets(num2);int len1 = strlen(num1);int len2 = strlen(num2);char temp[1000];char sum[2000] = {0};int j , l;for(int i = len1 - 1, k = 0; i >= 0; i--, k++) {int mark = 0;for( j = len2 - 1, l = k; j >= 0; j--,l++) {int num =( num1[i] - '0') * (num2[j] - '0') + mark;mark = num / 10;num = num % 10;temp[l] = num + '0';} if(mark > 0) {temp[l] = mark + '0';l++;}add(sum,temp,l);memset(temp,'0',sizeof(temp));}int len3 = 1999;if(num1[0] == '0' && len1 == 1 || num2[0] == '0' && len2 == 1)printf("0");else {for(;;len3--)if(sum[len3] != 0)break;for(int i = len3; i >= 0; i--) printf("%d",sum[i]);}printf("\n");}return 0;}
0 0
- UVA - 10106 Product 第二种解法
- UVa 10106 Product
- UVa OJ 10106-Product
- Uva 10106 Product
- uva 10106 Product
- UVa 10106 - Product
- uva-10106 - Product
- UVA 10106 Product
- UVA 10106 - Product
- UVa 10106 - Product
- UVa 10106 - Product
- Uva 10106 - Product
- UVa 10106 - Product
- UVa - 10106 - Product
- UVA 10106 Product
- UVa 10106 - Product
- uva 10106 Product
- UVa 10106 Product (高精度)
- SDUTOJ 2117 数据结构实验之链表二:逆序建立链表
- JSONP的方式检查用户名是否重复
- C# 委托实例(跨窗体操作控件)
- HTML5本地、离线、缓存、存储、数据库、文件
- navicat for mysql10.0.11简体中文破解版 CSDN免积分下载
- UVA - 10106 Product 第二种解法
- 6.DynamicProgramming
- c语言记录.1
- 为什么构造函数不能为虚函数
- SGU 217 Acdream 1234 Two Cylinders 自适应辛普森
- [计算机网络] 以太网数据帧(802.3)最大与最小长度
- 简单算法
- TOJ 3517 The longest athletic track(树直径)
- ACdream 1232 SGU 215 PL/Cool 手写了一个语法分析引擎