前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >数学趣题_父亲分羊

数学趣题_父亲分羊

作者头像
Zoctopus
发布2018-12-27 16:36:44
5400
发布2018-12-27 16:36:44
举报
文章被收录于专栏:章鱼的慢慢技术路

同步至 Github-WeeklyARTS-Algorithm

一、题目描述

有个老父亲,有17头羊,临终前把三个儿子叫来。分给大儿子一半的羊,二儿子1/3的羊,小儿子1/9的羊。三个儿子不知道怎么分,只好请教邻居。聪明的邻居借给了他们一头羊,这样总共就有18头。大儿子领走一半9头羊,二儿子领走1/3共6头羊,小儿子领走1/9,也就是2头羊。邻居最后把借的羊牵回去了。我们的问题是,满足这样条件的数字还有哪些?即遗产有n头羊,大儿子分得1/x, 二儿子分得1/y, 小儿子分得1/z,邻居借给一头羊。请编程找出这些满足条件的(n, x, y, z)。

二、题目分析

先估算出n的取值范围,再根据判断条件编写程序。

假如先从 1/2 + 1/3 + 1/4 开始计算结果值,发现其大于1,而我们需要找的是x y z三值加起来的结果小于等于1,因此我们对其中一个值不断增大。

当我们发现 1/2 + 1/3 + 1/7 小于1时,此时可以列不等式 1/2 + 1/3 + 1/7 >= n/n+1,解得 n <= 41。所以程序如下:

代码语言:javascript
复制
#include<stdio.h>
#include<math.h>
int main()
{
    int n,x,y,z,counter;
    for(x = 1;x < 50;x++){
        for(y = 1;y < 50;y++){
            for(z = 1; z < 50;z++){
                for(n = 1;n < 50;n++){
                    //判断条件 1,等式成立;2,x y z 三个值不相等;3,n要大于 x y z三个任一的值;4,x > y > z
                    if(((n+1)*(y*z + x*z + x*y) == n*x*y*z) && (x != y && x != z && y!=z) && ((n >= x && n >= y && n >= z))) {
                        if (x>y && y>z){
                            printf("n=%d,x=%d,y=%d,z=%d\n",n,x,y,z);
                            counter++;
                        }
                    }
                }
            }
        }
    }

    printf("满足条件的(n, x, y, z)为%d\n",counter);

    return 0;
}

/*
Output
n=19,x=5,y=4,z=2
n=11,x=6,y=4,z=2
n=41,x=7,y=3,z=2
n=23,x=8,y=3,z=2
n=17,x=9,y=3,z=2
n=14,x=10,y=3,z=2
满足条件的(n, x, y, z)为6
*/
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-12-19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、题目描述
  • 二、题目分析
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档