高精度(加減乘除)

来源:https://www.cnblogs.com/csclixuan/archive/2023/10/22/17780641.html
-Advertisement-
Play Games

高精度(加減乘除) 高精度的核心思想就是利用數組去儲存大數,然後通過模擬手動計算的方式,來進行計算。 主要分三個模塊: 1.讀入數據並轉換為(int)類型儲存 高精度加法 核心思想:將每個位上的數字都+起來,如果大於10就進位。 核心代碼如下: c[i]+=a[i]+b[i];//兩數相加 c[i+ ...


高精度(加減乘除)

高精度的核心思想就是利用數組去儲存大數,然後通過模擬手動計算的方式,來進行計算。

主要分三個模塊:

1.讀入數據並轉換為(int)類型儲存

高精度加法

核心思想:將每個位上的數字都+起來,如果大於10就進位。

核心代碼如下:

c[i]+=a[i]+b[i];//兩數相加
c[i+1]+=c[i]/10;//進位
c[i] = c[i]%10;//保留

完整代碼及解析如下:

string x, y;//兩個string類用來接收大數
//a接收x中的每一位數字,b用來接收y中的每一位數組,計算之後,儲存到c數組中
int a[999], b[999], c[999];
int main()
{
	cin >> x >> y;//讀入
	//將大數的每一位數轉換為(int)類型,然後倒序儲存
	for (int i = 0; i < x.length(); i++)
	{
		a[i] = x[x.length() - 1 - i]-'0';
	}
	for (int i = 0; i < y.length(); i++)
	{
		b[i] = y[y.length() - 1 - i]-'0';
	}
    
    //核心:開始計算
    //位數問題:兩個數相加,和的位數等於max(x.length(), y.length(),或者是其+1;
	for (int i = 0; i < max(x.length(), y.length()); i++)
	{
		c[i] += a[i] + b[i];//對應位數求和
		c[i + 1] += c[i] / 10;//進位
		c[i] = c[i] % 10;//保留
	}
    
    //下麵開始消除前導0
	int k = 0;//利用k來修正位數
	if (c[max(x.length(), y.length())] == 0)//如果最高位==0
	{
		k = 1;//k++輸出位數-1
	}
    //註意看k是如何控制位數的
	for (int i = max(x.length(), y.length())-k; i >=0 ; i--)
	{
		cout << c[i];
	}
	cout << endl;

    //完美落幕
	return 0;
}

高精度減法

減法核心:只使用大數減小數,如果某一位小於0,就向前一位借1

核心代碼如下:

c[i]+=a[i]-b[i];//兩數相減,儲存到c
if(c[i]<0)//如果小於0
{
    //借1
	c[i+1]--;
	c[i]+=10;
}

完整代碼及解析如下:

string x, y;//x和y用來接收大數
//a,b用來儲存大數的每一位數
int a[20000], b[20000], c[20000];
bool cmp(string x, string y)//比較x,y
{
    //先比較位數,位數長的一定是較大數
	if (x.size() != y.size())
	{
		return x.size() > y.size();
	}
	else//如果位數相同就從高到低比較每一位
	{
		for (int i = 0; i < x.size(); i++)
		{
            //如果某一位數字不相同就退出函數
			if (x[i] > y[i])
			{
				return true;
			}
			else if(x[i]<y[i])
			{
				return false;
			}
		}
        //如果一直相等就返回true
		return true;
        //註意返回值不能用return 0/1來寫
        //必須用return true/false
	}
}
int main()
{
	cin >> x >> y;
    //因為x-y有負數存在,所以我們只用大數減小數,最後補全-號就行
    //下麵進行比較:如果y比x大,就交換位置,並輸出-號
	if (cmp(x, y) == false)//詳見上方的cmp函數
	{
		swap(x, y);
		cout << "-";
	}
    //轉換為Int類型並倒序儲存
	for (int i = 0; i < x.length(); i++)
	{
		a[i] = x[x.length() - 1 - i]-'0';
	} 
	for (int i = 0; i < y.length(); i++)
	{
		b[i] = y[y.length() - 1 - i]-'0';
	}
    //核心代碼
    //位數問題:兩個數相減,差的位數最多是max(x.length(), y.length()
	for (int i = 0; i < max(x.length(), y.length()); i++)
	{
		c[i] += a[i] - b[i];
		if (c[i] < 0)//借1
		{
			c[i + 1] -= 1;
			c[i] += 10;
 		}	
	}
	int k = 0;
    //除0
	for (int i = max(x.length(), y.length()); i > 0; i--)
	{
		if (c[i] == 0)
		{
			k++;
		}
		else
		{
			break;
		}
	}
	for (int i = max(x.length(), y.length())-k; i >= 0; i--)
	{
		cout << c[i];
	}
	cout << endl;

	return 0;
}

高精度乘法

核心思想:利用兩數相乘的特點確定c的位置,之後同加法

位數問題:兩個數相乘,積的位數最多是兩個數的位數之和

核心代碼如下:

for (int i = 1; i <=x.length(); i++)
{
	for (int j = 1; j <= y.length(); j++)
	{
		c[i + j - 1]+= a[i] * b[j];//c的下標等於a,b的下標之和-1
		c[i + j] += c[i + j - 1] //10;進位
		c[i + j - 1] %= 10;//保留
	}
}

完整代碼及解析如下:

string x, y;
int a[99999], b[99999], c[99999];
int main()
{
	cin >> x >> y;
	for (int i = 0; i < x.length(); i++)
	{
		a[i+1] = x[x.length() - 1 - i]-'0';
	}
	for (int i = 0; i < y.length(); i++)
	{
		b[i+1] = y[y.length() - 1 - i]-'0';
	}
	//核心代碼
	for (int i = 1; i <=x.length(); i++)
	{
		for (int j = 1; j <= y.length(); j++)
		{
			c[i + j - 1]+= a[i] * b[j];
			c[i + j] += c[i + j - 1] / 10;
			c[i + j - 1] %= 10;
		}
	}
	//除0
	int k = 0;
	for (int i = x.length()+ y.length(); i >=2; i--)
	{
		if (c[i] == 0)
		{
			k++;
		}
		else
		{
			break;
		}
	}
	for (int i = x.length()+ y.length()-k; i >=1 ; i--)
	{
		cout << c[i];
	}
	cout << endl;

	return 0;
}

高精度除法(高精度除以低精度)

核心思想:利用手動除法的特點,將除法轉化為減法,再進行計算

核心代碼如下:

for (int i = 0; i < s.size(); i++)
{
	c[i] += (x * 10 + a[i]) / b;//將每次除法之後的餘數+a[i]之後再去除除數
	x = (x * 10 + a[i]) % b;//x為每次除法之後的餘數
}

完整代碼及解析如下

string s;
long long b;
long long a[99999], c[99999],x;
int main()
{
	cin >> s >> b;
    //註意除法時是正序輸入
	for (int i = 0;i<s.size();i++)
	{
		a[i] = s[i] - '0';
	}
    //核心代碼
	for (int i = 0; i < s.size(); i++)
	{
		c[i] += (x * 10 + a[i]) / b;
		x = (x * 10 + a[i]) % b;
	}
	//除0
	int k = 0;
	for (int i = 0; i < s.size()-1; i++)
	{
		if (c[i] == 0)
		{
			k++;
		}
		else
		{
			break;
		}
	}
	for (int i = k; i < s.size(); i++)
	{
		cout << c[i];
	}
	cout << endl;
	return 0;
}

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

-Advertisement-
Play Games
更多相關文章
  • 公司有一個新需求,在原來項目基礎上開發,項目中使用 Ant Design Vue,版本是 1.X ,在此記錄下遇到的問題;對於沒有使用過或者使用程度不深的同學來說,希望可以幫助你在開發中遇到問題時有個參考。對於已經熟練使用的同學,可能這些問題都遇到過,歡迎大家在評論區補充。 1、實現對下拉框顯示的所 ...
  • 這是我用於複習我一年前學習的JavaScript的筆記,由於一年過去了,我大概已經4~5個月沒有寫過什麼代碼,所以需要整理自己的知識體系,如果文章出錯,也希望大家評論給我改錯 JavaScript的類型 JS中的類型有以下幾種: Number(數字類型) BigInt (大數類型) String(字 ...
  • 接上一節:從零用VitePress搭建博客教程(4) – 如何自定義首頁佈局和主題樣式修改? 上一節其實我們也簡單說了自定義頁面模板,這一節更加詳細一點說明,開始之前我們要知道在vitePress中,.md的文件是可以直接編寫vue的代碼的。 比如我們現在來自定義一個前端網址導航頁面 八、自定義一些 ...
  • 2023年6月19日決定對rust做一個重新的梳理,整理今年4月份做完的rustlings,根據自己的理解來寫一份題解,記錄在此。 周折很久,因為中途經歷了推免的各種麻煩事,以及選擇資料庫作為未來研究方向後的一段適應過程,耽擱了很久。 2023年10月份秋冬季的開源操作系統訓練營又開始了,所以我回來 ...
  • 在⾯試過程中,應聘者可能想要從對公司環境的觀察以及對⾯試官的提問當中獲取公司相關的信息,以此來判斷這家公司靠不靠譜,⾃⼰值不值得去。但這種信息可能會帶有⼀定的⽚⾯性,畢竟 應聘者沒有在公司實際體驗過⼯作的內容,很難通過⼀兩次⾯試就能看出公司的實際情況。這些細節⼀般只能給予應聘者⼀點有效信息,雖然並不 ...
  • 實戰準備:要爬取的url:https://www.shicimingju.com/book/sanguoyanyi.html 實戰要求:爬取詩詞名句網站中的三國演義文章,將每章的標題和內容寫入自己的項目文件(sanguo.txt) (本次爬取使用bs4) 1 import requests 2 # ...
  • 編寫頁面這個程式設計工程師嘴上的口頭禪是在 2016 年在建行剛開始最開發的時候聽到的, 因為大學的時候學習的程式設計語言是一 C++為主,對於前端頁面這種能看到效果只是一種很難體會的概念。學習 C 語言程式設計的時候顯示在眼前的是一個命令行黑屏,學 C++, C#都是。作為大學生初學程式設計開發, ...
  • 我們通過類構造函數來創建對象,上文(第14天)我們學到,與Java不同,創建Dart對象時可以省略構造函數之前的new關鍵字。同時,Dart語言除預設構造函數外,還有命名構造函數,重定向構造函數,常量構造函數和工廠構造函數等…… ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...