演算法 之 aabb

来源:https://www.cnblogs.com/lzhh/archive/2018/01/13/acm_n0.html
-Advertisement-
Play Games

題目描述:輸出所有形如aabb的4位完全平方數(即前兩位數字相等,後兩位數字也相等)。 分支和迴圈結合在一起時功能強大: 下麵列舉所有可能的結果aabb,然後判斷它們是否為完全平方數。註意a的範圍是1~9,但b可以是0. 上面的程式並不完整——“aabb是完全平方數”是中文描述,而不是合法的C語言表 ...


題目描述輸出所有形如aabb4位完全平方數(即前兩位數字相等,後兩位數字也相等)

分支和迴圈結合在一起時功能強大:

下麵列舉所有可能的結果aabb,然後判斷它們是否為完全平方數。註意a的範圍是1~9,但b可以是0.                                  

1  for(int a=1;a<=9;a++)
2      for(int b=0;b<=9;b++)
3         If(aabb是完全平方數)
4                printf(“%d\n”,aabb);                       

        上面的程式並不完整——“aabb是完全平方數”是中文描述,而不是合法的C語言表達式,而aabb在C語言中也是另外一個變數,而不是把兩個數字a和b拼在一起。這個把這樣“不是真正程式”的“代碼”成為偽代碼(pseudocode)。雖然有一些正規的偽代碼的定義,但在實際應用中,並不需要太拘泥於為代碼的格式。主要的目標是描述演算法梗概,避開細節,啟發思路。

        寫出偽代碼之後,我們需要考慮如何把它變成真正的代碼。上面的偽代碼有兩個“非法”的地方;完全平方數判定,以及aabb這個變數。後者相對比較容易;用另外一個變數n=a×1100+b×11存儲即可。

接下來的問題就要困難一些了:如何判斷n是否為完全平方數?

方法一:PS(floor(x),也寫做Floor(x),其功能是“向下取整”,或者說“向下舍入”,即取不大於x的最大整數)

 1 #include<stdio.h>  
 2 #include<math.h>  
 3 int main()  
 4 {  
 5    for(int a=1;a<=9;a++)  
 6       for(int b=0;b<=9;b++)  
 7       {  
 8        int n=a*1100+b*11;//這裡開始使用n,因此在這裡定義n  
 9        int m=floor(sqrt(n)+0.5); 
10        if(m*m==n)  
11         printf("%d\n",n);  
12       }  
13    return 0;  
14 }  

         可不可以這樣寫?If(sqrt(n)==floor(sqrt(n))) printf(“%d\n”,n);即直接判斷sqrt(n)是否為整數。理論上當然沒問題,但這樣寫不保險,因為浮點數的運算(和函數)有可能存在誤差。假設在經過大量計算後,由於誤差的影響,整數1變成了0.99999999,floor的結果會是0而不是1,。為了減少誤差的影響,一般改成四捨五入,即floor(x+0.5)。如果難以理解,可以想象在數軸上把一個單位區間左移0.5個單元的距離。

Floor(x)等於1的區間為【1,2】,而floor(x+0.5)等於1的區間為【0.5,1.5】.

  浮點運算可能存在誤差。再進行浮點運算比較時,應考慮到浮點誤差。

  總結:小數部分為0.5的數也會受到浮點誤差的影響,因此任何一道嚴密的演算法競賽題目都需要想辦法解決這個問題

另一思路是枚舉平方根x,從而避免開方操作。

#include<stdio.h>  
int main()  
{  
   for(int x=1;;x++)     //for迴圈沒有指定迴圈條件  如果期待你從32開始可以不用判斷1000
   {  
      int n=x*x;  
    if(n<1000) continue;
if(n>9999) break; int high=n/100; int low=n%100; if(high/10==high%10&&low/10==low%10) printf("%d\n",n); } return 0; }

答案為

 

.


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

-Advertisement-
Play Games
更多相關文章
  • 以汽車工廠為例,首先有個汽車類的介面 Car,裡面有個開車的方法 drive(),然後有個寶馬車的類 BMW 和賓士車的類 Benz 實現了 Car 介面。 public interface Car{ public void drive(); } public class BMW implement ...
  • Python的網路編程主要支持兩種網路協議:TCP和UDP。這兩種協議都通過叫Socket的編程抽象進行處理。Socket起源於Unix,是類似於文件的存在,可以像文件一樣進行I/O、打開、關閉等操作,最主要的是它可以實現網路上不同主機的進程間通信,所以基本上Socket是任何一種網路通訊中最基礎的 ...
  • ###模塊calculate是自己寫的,出現紅色也可以調用 ###包導入包中的模塊 導入包中包的模塊 導入包中包模塊的方法 導入包解釋了__init__文件導入模塊和包的區別,導入模塊把模塊解釋了一遍,導入包只是解釋了__init__文件###項目中的模塊導入比較複雜簡單目錄結構,最後執行bin.p ...
  • #\n 回車符 #\r 換行符 #\s 空格 #\t tab符號,不知道?開個txt文本,然後按電腦的tab鍵,就是caps lock上面那個,卧槽,看到一個大長空格(也可能是個超短空格),這個就是tab符 #其他基本不會用,這幾個夠用了 #%d 數字 print '%d' %2 #%s 字元串 p ...
  • 對於中文亂碼問題,根據產生的原因,主要有以下幾種解決方案: 一、以Post方法提交的表單數據中有中文字元時。 這樣的話,就可以在獲取請求參數值之前,調用request對象的setCharacterEncoding("")方法,將請求的解碼方式設定為UTF-8。像這樣: 二、以GET方法提交的表單數據 ...
  • Python 支持三種不同的數字類型: 整型(Int) - 通常被稱為是整型或整數,是正或負整數,不帶小數點。Python3 整型是沒有限制大小的,可以當作 Long 類型使用,所以 Python3 沒有 Python2 的 Long 類型。 浮點型(float) - 浮點型由整數部分與小數部分組成 ...
  • 數組有工具類,方面操作數組 集合也有工具類:Collections 常用方法示例: ...
  • Map介面與Collection不同: Collection中的集合元素是孤立的,可理解為單身,是一個一個存進去的,稱為單列集合 Map中的集合元素是成對存在的,可理解為夫妻,是一對一對存進去的,稱為雙列集合 Map中存入的是:鍵值對,鍵不可以重覆,值可以重覆 Map介面中的常用集合: 1.Hash ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...