【藍橋杯】算法筆記1

1.暴力枚舉

給定一個正整數n,請找出所有滿足a2 + b2 = n的整數對(a, b),其中a和b都是正整數,且a ≤ b。

輸入格式:一個正整數n (1 ≤ n ≤ 10?)
輸出格式:所有符合條件的(a, b)對,每行一對,按a的升序排列。如果沒有符合條件的對,輸出"No solution"。

問題分析:我們需要找到所有滿足a2 + b2 = n的正整數對(a, b),其中a ≤ b。

枚舉策略:由于a和b都是正整數且a ≤ b,a的最大可能值是√(n/2),因為如果a > √(n/2),那么a2 > n/2,b2 = n - a2 < n/2 < a2,這將導致b < a,與a ≤ b矛盾。

算法選擇:采用枚舉算法,遍歷a的所有可能取值,對于每個a,計算b2 = n - a2,然后檢查b是否為整數。

優化:在枚舉a時,只需要枚舉到√(n/2)即可,減少不必要的計算。

import mathdef find_num(n):result=[]max_a=math.isqrt(n//2)  #計算n//2的整數平方根for a in range(1,max_a+1):remainder=n-a*ab=math.isqrt(remainder)if b*b==remainder and b>=a:result.append((a,b))return resultn=int(input("請輸入一個整數:"))
pairs=find_num(n)if not pairs:print("No solution")
else:for a,b in pairs:print(a,b)
input()

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/74864.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/74864.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/74864.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

專注自習室:番茄工作法實踐

專注自習室&#xff1a;番茄工作法實踐 我需要一個任務管理工具&#xff0c;但在網上找了很多都找不到合適的工具。市面上的大多數產品過于強調任務完成性&#xff0c;給我帶來了很強的心理壓力&#xff0c;這種壓力最終反而降低了我的工作效率。于是我決定自己動手&#xff0…

VUE3項目VITE打包優化

VUE3項目VITE打包優化 代碼加密依賴配置效果對比圖 自動導入依賴配置 代碼壓縮依賴配置效果對比圖 圖片壓縮依賴配置效果對比圖 字體壓縮總結與實踐運用效果 代碼加密 依賴 npm install -D vite-plugin-bundle-obfuscator配置 import vitePluginBundleObfuscator from "…

文章記單詞 | 第14篇(六級)

一&#xff0c;單詞釋義 affection&#xff1a;n. 喜愛&#xff0c;鐘愛&#xff1b;愛慕之情&#xff1b;感情stream&#xff1a;n. 小河&#xff0c;溪流&#xff1b;一連串&#xff0c;源源不斷&#xff1b;水流&#xff0c;氣流&#xff1b;vi. 流&#xff0c;流動&#x…

歐幾里得距離(Euclidean Distance)公式

歐幾里得距離公式 歐幾里得距離&#xff08;Euclidean Distance&#xff09;是計算兩點之間直線距離的一種方法。它是最常見的距離度量方式之一&#xff0c;廣泛應用于數學、物理、機器學習、計算機視覺等領域。 公式定義 1. 二維空間 在二維平面上&#xff0c;假設有兩個點…

機器學習——LightGBM

LightGBM(light gradient boosting machine&#xff0c;輕量梯度提升機)是對XGBoost進行改進的模型版本&#xff0c;其三者之間的演變關系為&#xff1a;GBDT-》XGBoost-》LightGBM&#xff0c;依次對性能進行優化&#xff0c;盡管XGBoost已經很高效了&#xff0c;但是仍然有缺…

內網服務器無法通過公網地址訪問映射到公網的內網服務

內網服務器無法通過公網地址訪問映射到公網的內網服務 問題現象問題原因解決方法總結 前幾天遇到一個網絡問題&#xff0c;在這里做下記錄&#xff0c;希望能幫助到有相同問題的朋友。 問題現象 網絡拓撲如上所示&#xff0c;服務器1和服務器2在同一內網&#xff0c;網段均為1…

python每日十題(13)

一般把計算機完成一條指令所花費的時間稱為一個指令周期。指令周期越短&#xff0c;指令執行就越快。本題答案為D選項。 順序程序具有順序性、封閉性和可再現性的特點&#xff0c;使得程序設計者能夠控制程序執行的過程(包括執行順序、執行時間&#xff09;&#xff0c;對程序執…

Python 裝飾器(Decorators)

什么是裝飾器&#xff1f; 裝飾器&#xff08;Decorator&#xff09;本質上是一個 修改其他函數功能的函數。它的核心思想是&#xff1a;不修改原函數代碼&#xff0c;動態添加新功能。比如&#xff1a; 記錄函數執行時間 檢查用戶權限 緩存計算結果 自動重試失敗操作 理解…

uWebSockets開發入門

一、常用C++ WebSocket開源庫 一些常用的 C++ WebSocket 開源庫,它們支持 WebSocket 協議的實現,適用于客戶端或服務器端開發。 1. Boost.Beast (推薦) 特點:基于 Boost.Asio 的高性能庫,支持 HTTP/WebSocket,屬于 Boost 官方庫的一部分,穩定且跨平臺。 適用場景:需要高…

多智能體功能分化的核心優勢是什么:提升效率,查漏補缺

多智能體功能分化的核心優勢是什么:提升效率,查漏補缺 在于通過分工協作提升整體效率、靈活性和魯棒性。 1. 提升效率與專業性 原理:單一智能體無需處理全流程,通過專業化分工減少冗余計算和決策延遲。 示例: 自動駕駛系統: 感知智能體:專門處理攝像頭、激光雷達等傳…

項目復盤:websocket不受跨域限制的原理

主要還是因為&#xff1a; 1、WebSocket 是獨立于 HTTP 的應用層協議&#xff0c;通過 HTTP 建立連接后&#xff0c;完全脫離 HTTP 語義約束。這意味著 不受 HTTP 同源策略限制 不需要預檢請求 不依賴 CORS 頭機制 2、建立連接時的握手請求仍使用 HTTP 格式&#xff0c;但…

COMPASS:通過殘差強化學習和技能合成實現跨具身移動策略

25年2月來自 Nvidia、UC Berkeley 和 UT Austin 的論文“COMPASS: Cross-embOdiment Mobility Policy via ResiduAl RL and Skill Synthesis”。 隨著機器人越來越多地部署在不同的應用領域&#xff0c;可泛化的跨具身移動策略變得越來越重要。雖然經典的移動棧已被證明在特定…

無人機,雷達定點飛行時,位置發散,位置很飄,原因分析

參考&#xff1a; 無人車傳感器 IMU與GPS數據融合進行定位機制_gps imu 組合定位原始數-CSDN博客 我的無人機使用雷達定位&#xff0c;位置模式很飄 雷達的更新頻率也是10HZ&#xff0c; 而px飛控的頻率是100HZ&#xff0c;沒有對兩者之間的頻率差異做出處理 所以才導致無人…

學習threejs,使用Sprite精靈、SpriteMaterial精靈材質

&#x1f468;??? 主頁&#xff1a; gis分享者 &#x1f468;??? 感謝各位大佬 點贊&#x1f44d; 收藏? 留言&#x1f4dd; 加關注?! &#x1f468;??? 收錄于專欄&#xff1a;threejs gis工程師 文章目錄 一、&#x1f340;前言1.1 ??THREE.Sprite1.1.1 ??代碼…

外星人入侵(python設計小游戲)

這個游戲簡而言之就是操作一個飛機對前方的飛船進行射擊&#xff0c;和一款很久之前的游戲很像&#xff0c;這里是超級低配版那個游戲&#xff0c;先來看看效果圖&#xff1a; 由于設計的是全屏的&#xff0c;所以電腦不能截圖。。。。 下面的就是你操控的飛船&#xff0c;上面…

什么是CMS?常用CMS有哪些?

一、內容管理系統&#xff08;Content Management System&#xff09;? ?什么是CMS?&#xff1a;位于 Web 前端&#xff08;服務器&#xff09;和后端辦公系統之間的軟件系統&#xff0c;用于內容創建、編輯、審批和發布。支持文本、圖片、視頻、數據庫等各類數字內容的管理…

Go 語言規范學習(3)

文章目錄 Properties of types and valuesRepresentation of valuesUnderlying types【底層類型】Core types【核心類型】Type identityAssignabilityRepresentabilityMethod sets BlocksDeclarations and scopeLabel scopesBlank identifierPredeclared identifiersExported i…

在 Ubuntu 上安裝 Docker 的完整指南

1. 卸載舊版本(如有) 在安裝新版本前,建議先卸載舊版本: sudo apt remove docker docker-engine docker.io containerd runc 2. 安裝依賴包 更新軟件包索引并安裝必要的依賴: sudo apt update sudo apt install -y ca-certificates curl gnupg lsb-release 3. 添加 Do…

turtle的九個使用

一 import turtle as t color [red,green,blue,orange,pink] for i in range(len(color)):t.penup()t.goto(-20070*i,0)t.pendown()t.pencolor(color[i])t.circle(50, steps 5) t.done()二 #在____________上補充代碼 #不要修改其他代碼import random as r import turtle a…

23種設計模式-備忘錄(Memento)設計模式

備忘錄設計模式 &#x1f6a9;什么是備忘錄設計模式&#xff1f;&#x1f6a9;備忘錄設計模式的特點&#x1f6a9;備忘錄設計模式的結構&#x1f6a9;備忘錄設計模式的優缺點&#x1f6a9;備忘錄設計模式的Java實現&#x1f6a9;代碼總結&#x1f6a9;總結 &#x1f6a9;什么是…