信息学奥赛一本通(1150:求正整数2和n之间的完全数)
生活随笔
收集整理的這篇文章主要介紹了
信息学奥赛一本通(1150:求正整数2和n之间的完全数)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1150:求正整數2和n之間的完全數
時間限制: 1000 ms ??? ??? 內存限制: 65536 KB
提交數: 30272 ??? 通過數: 18285
【題目描述】
求正整數22和nn之間的完全數(一行一個數)。
完全數:因子之和等于它本身的自然數,如6=1+2+36=1+2+3
【輸入】
輸入n(n≤5000)n(n≤5000)。
【輸出】
一行一個數,按由小到大的順序。
【輸入樣例】
7【輸出樣例】
6【參考代碼】
#include <stdio.h> #include <math.h> int isperfect_number(int n) {int i,k,s=1;k=sqrt(n);for(i=2;i<=k;i++){if(n%i==0)s+=i+n/i;}if(s==n)return 1;elsereturn 0; } int main() {int i,n;scanf("%d",&n);for(i=2;i<=n;i++){if(isperfect_number(i))printf("%d\n",i);}return 0; }http://ybt.ssoier.cn:8088/problem_show.php?pid=1150
?
總結
以上是生活随笔為你收集整理的信息学奥赛一本通(1150:求正整数2和n之间的完全数)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 信息学奥赛一本通 1982:【19CSP
- 下一篇: 信息学奥赛一本通 1099:第n小的质数