当前位置: 首页 > news >正文

Ul设计网站云南建设学院的网站

Ul设计网站,云南建设学院的网站,北海 网站制作工,昨晚贵州出大事AcWing 793. 高精度乘法 题目描述 给定两个非负整数(不含前导 00) A 和 B,请你计算 AB 的值。 输入格式 共两行,第一行包含整数 A,第二行包含整数 B。 输出格式 共一行,包含 AB 的值。 数据范围 1≤…

AcWing 793. 高精度乘法

题目描述

给定两个非负整数(不含前导 00) A 和 B,请你计算 A×B 的值。

输入格式

共两行,第一行包含整数 A,第二行包含整数 B。

输出格式

共一行,包含 A×B 的值。

数据范围

1≤A 的长度≤100000,

0≤B≤100000

输入样例

2
3

输出样例

6

思路

将 B 看成一个整体再相乘,不要一位一位的乘!注意结果的前导 0!

C++

#include <iostream>
#include <string>using namespace std;void reverse(string &s) {size_t n = s.length();for (int i = 0; i < n / 2; ++i) {swap(s[i], s[n - i - 1]);}
}string mul(string &a, int b) {reverse(a);int carry = 0;string result;for (size_t i = 0; i < a.size() || carry; ++i) {if (i < a.size()) carry += (a[i] - '0') * b;result.push_back(carry % 10 + '0');carry /= 10;}reverse(result);if (result[0] == '0') return "0";return result;
}int main() {string a;int b;cin >> a >> b;cout << mul(a, b);return 0;
}
#include <iostream>
#include <vector>using namespace std;vector<int> mul(vector<int> &A, int b)
{vector<int> C;int t = 0;for (int i = 0; i < A.size() || t; i ++ ){if (i < A.size()) t += A[i] * b;C.push_back(t % 10);t /= 10;}while (C.size() > 1 && C.back() == 0) C.pop_back();return C;
}int main()
{string a;int b;cin >> a >> b;vector<int> A;for (int i = a.size() - 1; i >= 0; i -- ) A.push_back(a[i] - '0');auto C = mul(A, b);for (int i = C.size() - 1; i >= 0; i -- ) printf("%d", C[i]);return 0;
}

Go

package mainimport ("fmt""strings"
)func reverse(s string) string {r := []rune(s)l := len(r)for i := 0; i < l/2; i++ {r[i], r[l-i-1] = r[l-i-1], r[i]}return string(r)
}func mul(a string, b int) string {a = reverse(a)carry := 0var result strings.Builderfor i := 0; i < len(a) || carry > 0; i++ {if i < len(a) {carry += int(a[i]-'0') * b}result.WriteByte(uint8(carry%10) + '0')carry /= 10}resStr := reverse(result.String())if resStr[0] == '0' {return "0"}return resStr
}func main() {var a stringvar b intfmt.Scanln(&a)fmt.Scanln(&b)fmt.Println(mul(a, b))
}

模板

// C = A * b, A >= 0, b >= 0
vector<int> mul(vector<int> &A, int b)
{vector<int> C;int t = 0;for (int i = 0; i < A.size() || t; i ++ ){if (i < A.size()) t += A[i] * b;C.push_back(t % 10);t /= 10;}while (C.size() > 1 && C.back() == 0) C.pop_back();return C;
}
http://www.yayakq.cn/news/320250/

相关文章:

  • 门户类网站前台网站推广排名收费标准
  • 天津高端网站建设公司自做淘宝客网站
  • 洛阳网站建设外包长春网络公司有哪些
  • 网站用什么软件程序做金馆长做图网站
  • 做一个网站需要多少钱my21777域名查询
  • 车子网站网站建设的网页怎么做
  • 专业的个人网站建设哪家便宜怎么在运行打开wordpress
  • 宝盈集团直营网站怎么做网址怎么推广
  • 公司网站开发费能记研发费用哪个科目建一个手机网站需要多少钱
  • 有什么做视频的免费素材网站好.net做网站开发
  • 福州网站建设优质服务商龙岩建设局网站
  • 网站建设与准备新乡做网站公司
  • 广州新塘做网站免费网站怎么做
  • 如何选择番禺网站建设在线房产网
  • 商城展示网站建设招生网站建设策划方案
  • 移动网站开发技术有哪些自建网站系统
  • 网站建设金手指稳定网页设计范文
  • 南海网站制作wordpress能进后台进不去首页
  • 金山专业做网站在线设计平台优缺点
  • 潍坊网站建设方案咨询3liang 设计网站 源码
  • 霸州 网络 网站建设做网站需要哪些条件
  • 门户网站建设方案公司凡客诚品创建时间
  • 网站模板购买 优帮云重庆网建
  • 京东网站建设机构公司宣传页的样板
  • 一般做网站要多少钱洛阳高新区做网站公司
  • 网站套餐百度竞价品牌广告
  • 西安企业网站开发哪家好做搜索的网站
  • 网站建设忘记密码邮箱设置网络营销成功案例ppt免费
  • 网站下载器石家庄外贸网站建设
  • 原创设计师品牌网站wordpress会员收费插件