| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 770 人关注过本帖
标题:各位哥哥姐姐,帮帮忙,谢谢,求亲密数
只看楼主 加入收藏
desolateyy
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-6-10
结帖率:0
收藏
已结贴  问题点数:20 回复次数:5 
各位哥哥姐姐,帮帮忙,谢谢,求亲密数
我是个新手,刚写这个,老师留了个作业:“请打印出 5000 以内的全部亲密数。”
我还不是很明白,各位哥哥姐姐能帮帮忙吗?谢谢了
搜索更多相关主题的帖子: 姐姐 老师 
2011-06-10 10:55
记叙、继续
Rank: 4
等 级:业余侠客
帖 子:56
专家分:226
注 册:2011-5-17
收藏
得分:4 
应该就是相连的数吧,用变量加一
2011-06-10 11:45
wyhaoshuai
Rank: 2
等 级:论坛游民
帖 子:5
专家分:44
注 册:2011-6-9
收藏
得分:4 
亲密数的定义有吗
2011-06-10 15:55
voidx
Rank: 12Rank: 12Rank: 12
来 自:邯郸
等 级:火箭侠
帖 子:1250
专家分:3538
注 册:2011-4-7
收藏
得分:4 
设有正整数 a,b 和 k,a != b。
若 k < a 且 a % k == 0,称 k 为 a 的真因子。
若 a 的所有真因子的和等于 b,且 b 的所有真因子的和等于 a,则称 a,b 互为亲密数。

楼主能想到怎么做了么?

[ 本帖最后由 voidx 于 2011-6-10 16:11 编辑 ]
2011-06-10 16:09
lianjiecuowu
Rank: 3Rank: 3
来 自:安徽
等 级:论坛游侠
帖 子:152
专家分:107
注 册:2011-5-20
收藏
得分:4 
#include<iostream>
using namespace std;
int main()
{
    int a,b,k;
    cout<<"这是关于b的亲密数:"<<endl;
    for(b=1;b<5000;b++)
    {
           for(a=1;a<5000,a!=b;a++)
           {
            int m=0;
           for(k=1;k<a;k++)
           {
               if(a%k==0)
               m+=k;
           }
            if(m==b)
            {
                cout<<"a="<<a<<"\t"<<"b="<<b<<'\t';
            }
           }
         
    }

    cout<<endl<<endl;
    cout<<"这是关于a的亲密数:"<<endl;
    for(a=1;a<5000;a++)
    {
           for(b=1;b<5000,b!=a;b++)
           {
            int n=0;
           for(k=1;k<n;k++)
           {
               if(b%k==0)
               n+=k;
           }
            if(n==a)
            {
                cout<<"b="<<b<<"\t"<<"a="<<a<<'\t';
            }
           }
         
    }
    system("pause");
    return 0;
   
}

Sharp your mind!
2011-06-11 08:37
小R
Rank: 1
等 级:新手上路
帖 子:1
专家分:4
注 册:2011-4-15
收藏
得分:4 
#include<iostream>
#define M 5000
using namespace std;
int f(int a)
{
    int i, sum=0, k;
    k=a/2+1;
    for(i=1; i<k; i++)
    {
        if(a%i==0)
        {
            sum+=i;
        }
    }
    return sum;
}

int main()
{
    int num=1, i, j, sum;
    while(num++<M)
    {
        sum = f(num);
        if(sum>num && sum<M && num==f(sum))
        {
            printf("(%d, %d)\n", num, sum);
        }
    }
    return 0;
}
2011-06-12 14:41
快速回复:各位哥哥姐姐,帮帮忙,谢谢,求亲密数
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016543 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved