| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付学习型 ASP/PHP/ASP.NET 主机 30元/年
高端软件开发 = 年薪十万不是梦   
共有 982 人关注过本帖
标题:有几道题,想请大虾们帮个忙
收藏  订阅  推荐  打印
阿戴
Rank: 1
等级:新手上路
帖子:36
积分:466
注册:2007-12-31
有几道题,想请大虾们帮个忙

1.海滩上有一堆桃子,5只猴子来分。第一只猴子把这堆桃子凭据分为5份,多了一个,这只猴子把多的一个仍入海中,拿走了一份。第二只猴子把剩下的桃子又分成5份,有多了一个,它同样把多的一个仍入海中,拿走了一份。第三,第四,第五只猴子都是这样做的。问:海滩上原来最少有多少个桃子?

  2.对于一个输入的数组(假定有10个元素),请将其中最大的与第一个元素交换,最小的与最后一个元素交换,并将交换后的数组输出。

  3.打印楼梯,同时在楼梯上方打印两个笑脸。
2008-6-14 15:46
learnerboy
Rank: 2
等级:注册会员
帖子:123
积分:1334
注册:2007-11-11

第二题
#include<stdio.h>
#define N 10
void forw(int *array);
void swap(int &a,int &b);
void main()
{
    int i,a[N];
    printf("请给数组赋值==>>");
    for(i=0;i<N;i++)
        scanf("%d",&a[i]);
    forw(a);
    printf("\n换值后的数组为==>>");
    for(i=0;i<N;i++)
        printf("%4d",a[i]);
    printf("\n");
}
void forw(int *array)
{
    int i,point1,point2,max=array[0],min=array[0];
    for(i=1;i<N;i++)
    {
        if(max<array[i])
        {
            max=array[i];
            point1=i;
            continue;
        }
        if(min>array[i])
        {
            min=array[i];
            point2=i;
        }
    }
    swap(array[0],array[point1]);
    swap(array[N-1],array[point2]);
}
void swap(int &a,int &b)
{
    int temp;
    temp=a;
    a=b;
    b=temp;
}
2008-6-14 16:26
simpley
Rank: 3Rank: 3
等级:中级会员
帖子:261
积分:2826
注册:2005-2-23

我给第一题推导出来的一个公式:
M*(M^(M-1)-1)+1
其中M是猴子的个数.

程序简化到了极点.

[ 本帖最后由 simpley 于 2008-6-14 17:35 编辑 ]

myQQ::445750010
2008-6-14 17:30
阿戴
Rank: 1
等级:新手上路
帖子:36
积分:466
注册:2007-12-31
。。

呵呵,是很简化
2008-6-14 18:07
simpley
Rank: 3Rank: 3
等级:中级会员
帖子:261
积分:2826
注册:2005-2-23

发现猴子扔掉的桃子数目改变后仍适用本公式:
M*(M^(M-1)-P)+P
M是猴子数,P是猴子扔掉的桃子数,其中P只须小于(M-1)^(M-1)即可.这样可以保证最后的猴子至少能分得1个桃子

myQQ::445750010
2008-6-14 18:39
阿戴
Rank: 1
等级:新手上路
帖子:36
积分:466
注册:2007-12-31

还是看不懂
原来的桃子是多少
2008-6-14 21:26
阿戴
Rank: 1
等级:新手上路
帖子:36
积分:466
注册:2007-12-31

你测试过没有,如果可以,能发断程序上来不?
2008-6-14 21:27
simpley
Rank: 3Rank: 3
等级:中级会员
帖子:261
积分:2826
注册:2005-2-23

没有试过,但肯定不会错

myQQ::445750010
2008-6-14 21:38
阿戴
Rank: 1
等级:新手上路
帖子:36
积分:466
注册:2007-12-31
回复 2# learnerboy 的帖子

你测试过没,我测试,有2个错误の
2008-6-15 08:42
himpo
Rank: 2
等级:注册会员
帖子:132
积分:1612
注册:2008-5-16

2#的代码有问题
如果一开始a[0]最小,而a[N-1]最大
min和max初值为a[0]
循环后point2连赋初值的机会都没有,更别提后面a[point2]的交换了.
即便改为min>=a[i]
此时point1=N-1而point2=0,
后面的两个交换为a[0]和a[N-1]的两次交换,结果数组不变。


还有你先交换的是最大值max
如果一开始数组最小值在a[0] 即point2=0
在第一次交换后最小值跑到了a[point1]去了,a[0]不再是最小值,
在你交换最小值的时候你用a[point2](即a[0])和a[N-1]交换,结果可想而知。。错误!

[ 本帖最后由 himpo 于 2008-6-15 08:58 编辑 ]

[ 本帖最后由 himpo 于 2008-6-15 09:00 编辑 ]
2008-6-15 08:53
共有 981 人关注过本帖
发新话题
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.055265 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved