【洛谷P1303A*Bprublem】

来源:https://www.cnblogs.com/juruohqk/archive/2019/03/02/10463035.html
-Advertisement-
Play Games

題目描述 求兩數的積。 輸入輸出格式 輸入格式: 兩行,兩個數。 輸出格式: 積 輸入輸出樣例 輸入樣例#1: 1 2 輸出樣例#1: 2 說明 每個數字不超過10^2000,需用高精 這道題還是比較良心的,畢竟在說明中提示了要用高精,那麼就要我們用到高精的乘法演算法,代碼如下: #include<c ...


題目描述

求兩數的積。

輸入輸出格式

輸入格式:

兩行,兩個數。

輸出格式:

輸入輸出樣例

輸入樣例#1: 
1 
2
輸出樣例#1: 
2

說明

每個數字不超過10^2000,需用高精

 

這道題還是比較良心的,畢竟在說明中提示了要用高精,那麼就要我們用到高精的乘法演算法,代碼如下:

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<string>
#include<cmath>
#include<algorithm>
#include<iomanip>//本蒟蒻習慣打上所有頭文件;
using namespace std;
int main()
{
    char a1[2001],b1[2001];
    int a[2001]={},b[2001]={},c[200001]={},lena,lenb,lenc,i,j,x;//把a,b,c,數組清零,也可以用memset(a/b/c,0,sizeof(a/b/c));x代表進位數。
    scanf("%s",a1);
    scanf("%s",b1);//對於洛谷的輸入格式,用gets可能會卡bug。
    lena=strlen(a1);lenb=strlen(b1);//計算a1、b1的長度,便於後面的迴圈和進位。
    for(i=0;i<=lena-1;i++) a[lena-i]=a1[i]-48;
    for(i=0;i<=lenb-1;++i) b[lenb-i]=b1[i]-48;//把字元數組中的數存在a、b數組中,可以像本代碼中直接對字元進行計算,也可以用強制類型轉換來轉換。
    for(i=1;i<=lena;++i)//外迴圈用於對第一個數的每一個數進行計算。
    {
        x=0;//一定要記住把進位數在內迴圈內清零,否則將會出現意想不到的效果。
        for(j=1;j<=lenb;j++)//內迴圈用於對第二個數的計算。
        {
            c[i+j-1]=a[i]*b[j]+x+c[i+j-1];//把第i+j-1個數賦值,(至於為啥是第i+j-1個數,可以自己推一推,直接記住就行)它的值就是第一個數的第i位於第二個數的第j位之積加上進位的數(包括上一位進的數與上一個迴圈進的數)。
            x=c[i+j-1]/10;//進位處理,取該數的進位數。
            c[i+j-1]%=10;//保留個位數。
        }
        c[i+lenb]=x;//將內迴圈沒有進完的數進到下一個迴圈內。
    }
    lenc=lena+lenb;//計算c數組的最大長度。
    while(c[lenc]==0&&lenc>1)//c[lenc]==0是對0的判定,如果該位不是0,且滿足lenc>1(希望有大神指點一下為什麼要判定這個,我將這個去掉後也沒有什麼區別),就輸出。
       lenc--;//保證迴圈開始時不是0。
    for(i=lenc;i>=1;i--)//迴圈輸出c數組。
       cout<<c[i];
    cout<<endl;
    return 0;//好習慣別忘記。
}

高精乘法計算就是把我們平時用豎式做的乘法轉化成更智障的演算法,例如53*79:

                                       5    3

                                 x    7    9


                                       2    7

                        +       4    5

                        +       2    1

                        +3     5


                          4     1    8   7

通過程式就可以處理10的n次方之間的乘法,真的很實用。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我的其他隨筆: 來一局緊張刺激的吃雞——淺談裝飾者模式 一起去開心的購物吧——淺談觀察者模式 記一場精彩的籃球比賽——淺談策略模式 大家好,前幾日連夜更了幾篇Java設計模式的小隨筆,從觀看量來說,我還是很高興的,有很多的朋友通過看了博文,也許接觸了新的知識,也許理解了自己之前沒弄懂的東西,也許只是 ...
  • 最近偶然到博客園看了一下,距離上次的博客已經過去很多天了,閱讀量卻少得可憐,對於博客園小白來說感覺不是很友好(主要是心理不平衡),而且有些博客被其他網站不帶出處的裝載了,它的閱讀量卻很多。於是靈光一閃,決定寫個程式增加一下閱讀量。(僅用於學術交流,實際上我就試了一下,沒有真正刷過) 一、原理 一般來 ...
  • 先看一段java代碼,func返回值為int: 正確的返回結果是,func返回1。 原因:如果finally中沒有return語句,但是改變了要返回的值,這裡有點類似與引用傳遞和值傳遞的區別,分以下兩種情況,: 1)如果return的數據是基本數據類型或文本字元串,則在finally中對該基本數據的 ...
  • 準備 安裝 "vscode" ,可直接下載deb包進行安裝,完成後安裝C/C++ for Visual Studio Code插件,安裝後重啟(最新1.3版本以後不需要重啟)。 生成目錄和文件 新建文件夾【test】,並新建文件helloworld.cpp文件,文件中內容如下, include in ...
  • 使用python-kafka類庫開發kafka生產者&消費者&客戶端 By: 授客 QQ:1033553122 1.測試環境 python 3.4 zookeeper-3.4.13.tar.gz 下載地址1: http://zookeeper.apache.org/releases.html#dow ...
  • 1 #include <stdio.h> 2 #include <stdlib.h> 3 #include <string.h> 4 5 #define PRINTF_DEBUG 6 7 #define BOX_TYPE_FTYPE "ftyp" 8 #define BOX_TYPE_MOOV "m ...
  • 1 #include <stdio.h> 2 #include <stdlib.h> 3 #include <string.h> 4 #include <arpa/inet.h> 5 6 #define TAB44 " " 7 #define PRINTF_DEBUG 8 9 #define MAX ...
  • 本講主要內容 2.1 變數 1. 變數是什麼? 變數,是指把程式運行的中間結果臨時的存在記憶體里,以便後續的代碼調用,其值可以修改。 在python中,當變數被使用時,在記憶體里將產生兩個動作,一是開闢指定地址的空間,二是賦予指定的變數值。 在python語言中,變數在指定的同時,必須強制賦初值,否則解 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...