亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++中約數(shù)定理的實例詳解

 更新時間:2017年07月08日 10:33:27   投稿:lqh  
這篇文章主要介紹了C++中約數(shù)定理的實例詳解的相關(guān)資料,需要的朋友可以參考下

C++中約數(shù)定理的實例詳解

對于一個大于1正整數(shù)n可以分解質(zhì)因數(shù):n = p1^a1*p2^a2*......pk^ak,則n的正約數(shù)的個數(shù)就是  :(a1+1)*(a2+1)*......*(ak+1)

其中a1、a2、a3…ak是p1、p2、p3,…pk的指數(shù)。

用這個定理求一個數(shù)的約數(shù)個數(shù)是非常快的,貼出一道訓(xùn)練題目:

hdu 1492 -求約數(shù)的個數(shù)

貼出代碼:

//約數(shù)定理的 
#include <iostream> 
#include <algorithm> 
#include <iterator> 
#include <cstdio> 
#include <cstdlib> 
#include <cmath> 
#include <cstring> 
#include <vector> 
#include <queue> 
#include <set> 
using namespace std; 
 
#define ll long long 
 
int main() 
{ 
  // freopen("s.cpp","r",stdin); 
 
  ll n; 
  while(scanf("%lld",&n) != EOF) 
  { 
    if(!n) break; 
 
    ll sum = 1; 
    /* x = p1^a1*p2^a2*p3^a3...pk^ak 
    yueshu = (a1+1)*(a2+1)*...*(ak+1)*/ 
    for(ll i = 2; i*i <= n; i++){ 
      int cou = 0; 
      if(n%i==0){ 
        cou = 1; 
        n /= i; 
        while(n%i==0){ 
          cou++; 
          n /= i; 
        } 
      } 
      if(cou != 0){ 
        sum = sum*(cou+1); 
      } 
    } 
    if(n != 1){ 
      sum = sum*2; 
    } 
    if(sum==1 && n==1){ 
      sum = 1; 
    } 
    printf("%lld\n",sum); 
  } 
  return 0; 
} 

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • C++獲取MD5算法實現(xiàn)代碼

    C++獲取MD5算法實現(xiàn)代碼

    這篇文章主要介紹了C++獲取MD5算法實現(xiàn)代碼,這個是網(wǎng)上扒下來的 作者已經(jīng)無法知道是誰了 ,可以備用
    2019-04-04
  • C++ 獲取URL內(nèi)容的實例

    C++ 獲取URL內(nèi)容的實例

    這篇文章主要介紹了C++ 獲取URL內(nèi)容的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • C語言 棧的表示和實現(xiàn)詳細(xì)介紹

    C語言 棧的表示和實現(xiàn)詳細(xì)介紹

    這篇文章主要介紹了C語言 棧的表示和實現(xiàn)詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • C++實現(xiàn)LeetCode(150.計算逆波蘭表達(dá)式)

    C++實現(xiàn)LeetCode(150.計算逆波蘭表達(dá)式)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(150.計算逆波蘭表達(dá)式),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 詳解C/C++高精度算法的簡單實現(xiàn)

    詳解C/C++高精度算法的簡單實現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了C/C++中高精度算法(加減乘除)的簡單實現(xiàn),方便以后需要時拷貝使用。感興趣的小伙伴可以跟隨小編一起了解一下
    2022-12-12
  • C++ Boost.Signals2信號/槽概念

    C++ Boost.Signals2信號/槽概念

    Boost是為C++語言標(biāo)準(zhǔn)庫提供擴展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴展的一些C++程序庫的總稱
    2022-12-12
  • C語言全面梳理文件操作方法

    C語言全面梳理文件操作方法

    這篇文章主要為大家詳細(xì)介紹了C語言的文件操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-05-05
  • Qt控件點擊消息獲取的方法詳解

    Qt控件點擊消息獲取的方法詳解

    本文將利用Qt中的QLabel、QPushButton這兩個控件,為大家詳細(xì)介紹一下Qt控件點擊消息獲取的方法,文中的示例代碼講解詳細(xì),感興趣的可以了解一下
    2022-06-06
  • C++判斷子序列題目詳解

    C++判斷子序列題目詳解

    這篇文章主要為大家介紹了C++判斷子序列題目,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • C++實例輸入多行數(shù)字到數(shù)組

    C++實例輸入多行數(shù)字到數(shù)組

    這篇文章主要介紹了C++實例輸入多行數(shù)字到數(shù)組的相關(guān)資料,這里提供實例代碼幫助大家學(xué)習(xí)理解,需要的朋友可以參考下
    2016-12-12

最新評論