用長整數求取普通整數的階乘

2021-04-14 09:38:37 字數 2153 閱讀 2954

袁紅崗的程式設計師修煉之道

**引言:

袁紅崗1994

年加盟金蝶,

1996

年在整個行業還處在

dos時代時最早成功開發出基於

windows

平台的金蝶財務軟體,開創了依靠技術創新推動企業快速發展的典範;

1998

年成功開發出基於三層結構元件技術的金蝶

k/3系統並引入金蝶企業應用軟體;率領當時的金蝶**研究院開始了

j2ee

架構的核心

--j2ee

應用伺服器的研究和開發,成功開發出國內首家擁有完全自主智財權、並第乙個通過國際

j2ee

認證的金蝶

apusic

應用伺服器,並成為國際

jcp組織中國代表。看了袁

大牛人的簡史,在想想自己成天擺弄的哪些修修補補的破銅爛鐵、碎瓷爛瓦;無地自容之至。更為自己曾經大言不慚的建議「正確地做事與做正確的事同樣重要」感到幼稚。但略感欣慰的是:自己的部分觀點也略望其項背、不至怡笑大方。

不知不覺做軟體已經做了十年,有成功的喜悅,也有失敗的痛苦,但總不敢稱自己是高手,因為和我心目中真正的高手們比起來,還差的太遠。世界上並沒有成為高手的捷徑,但一些基本原則是可以遵循的。

1. 紮實的基礎。資料結構、離散數學、編譯原理,這些是所有電腦科學的基礎,如果不掌握他們,很難寫出高水平的程式。據我的觀察,學計算機專業的人比學其他專業的人更能寫出高質量的軟體。程式人人都會寫,但當你發現寫到一定程度很難再提高的時候,就應該想想是不是要回過頭來學學這些最基本的理論。不要一開始就去學oop,即使你再精通oop,遇到一些基本演算法的時候可能也會束手無策。

2. 豐富的想象力。不要拘泥於固定的思維方式,遇到問題的時候要多想幾種解決問題的方案,試試別人從沒想過的方法。

豐富的想象力是建立在豐富的知識的基礎上

,除計算機以外,多涉獵其他的學科,比如天文、物理、數學等等。另外,多看科幻電影也是乙個很好的途徑。

3.最簡單的是最好的。這也許是所有科學都遵循的一條準則,如此複雜的質能互換原理在愛因斯坦眼裡不過是乙個簡單得不能再簡單的公式:e=mc2。簡單的方法更容易被人理解,更容易實現,也更容易維護。遇到問題時要優先考慮最簡單的方案,只有簡單方案不能滿足要求時再考慮複雜的方案。

4. 不鑽牛角尖。當你遇到障礙的時候,不妨暫時遠離電腦,看看窗外的風景,聽聽輕**,和朋友聊聊天。當我遇到難題的時候會去玩遊戲,而且是那種極暴力的打鬥類遊戲,當負責遊戲的那部分大腦細胞極度亢奮的時候,負責程式設計的那部分大腦細胞就得到了充分的休息。當重新開始工作的時候,我會發現那些難題現在竟然可以迎刃而解。

5. 對答案的渴求。人類自然科學的發展史就是乙個渴求得到答案的過程,即使只能知道答案的一小部分也值得我們去付出。只要你堅定信念,一定要找到問題的答案,你才會付出精力去探索,即使最後沒有得到答案,在過程中你也會學到很多東西。

6. 多與別人交流。三人行必有我師,也許在一次和別人不經意的談話中,就可以迸出靈感的火花。多上上網,看看別人對同一問題的看法,會給你很大的啟發。

7.良好的程式設計風格。注意養成良好的習慣,**的縮排編排,變數的命名規則要始終保持一致。大家都知道如何排除**中錯誤,卻往往忽視了對注釋的排錯。注釋是程式的乙個重要組成部分,它可以使你的**更容易理解,而如果**已經清楚地表達了你的思想,就不必再加注釋了,如果注釋和**不一致,那就更加糟糕。

8.韌性和毅力。這也許是"高手"和一般程式設計師最大的區別。高手們並不是天才,他們是在無數個日日夜夜中磨練出來的。

成功能給我們帶來無比的喜悅,但過程卻是無比的枯燥乏味

。你不妨做個測試,找個10000以內的素數表,把它們全都抄下來,然後再檢查三遍,如果能夠不間斷地完成這一工作,你就可以滿足這一條。

這些是我這幾年程式設計師生涯的一點體會,希望能夠給大家有所幫助。 

用python實現長整數加法

問題描述 輸入兩個整數a和b,輸出這兩個整數的和。a和b都不超過100位。演算法描述 由於a和b都比較大,所以不能直接使用語言中的標準資料型別來儲存。對於這種問題,一般使用陣列來處理。定義乙個陣列a,a 0 用於儲存a的個位,a 1 用於儲存a的十位,依此類推。同樣可以用乙個陣列b來儲存b。計算c ...

長整數的乘法

思路比較簡單但是編寫程式特別容易出錯,思路就是用字串來模擬乘法的計算,錯誤的地方在於,字串的低位恰恰是其代表的長整數的高位 測試用例 include include cexampletest.h include include include extern char longintegermul c...

用C語言處理長整數的計算

宣告 本人所作部落格均為自己學習複習所用 題目 假定用乙個整型陣列表示乙個長整數,陣列的每個元素儲存長整數的一位數字,實際的長整數m表示為 m a k 10k 1 a k 1 10k 2 a 2 10 a 1 其中a 0 儲存該長整數的位數。完成 長整數乘普通整數。include include v...