当前位置: 代码迷 >> C语言 >> 有几道题,想请大虾们帮个忙
  详细解决方案

有几道题,想请大虾们帮个忙

热度:382   发布时间:2008-06-14 15:46:19.0
有几道题,想请大虾们帮个忙
1.海滩上有一堆桃子,5只猴子来分。第一只猴子把这堆桃子凭据分为5份,多了一个,这只猴子把多的一个仍入海中,拿走了一份。第二只猴子把剩下的桃子又分成5份,有多了一个,它同样把多的一个仍入海中,拿走了一份。第三,第四,第五只猴子都是这样做的。问:海滩上原来最少有多少个桃子?

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

  3.打印楼梯,同时在楼梯上方打印两个笑脸。
搜索更多相关的解决方案: 猴子  桃子  元素  海滩  

----------------解决方案--------------------------------------------------------
第二题
#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;
}
----------------解决方案--------------------------------------------------------
我给第一题推导出来的一个公式:
M*(M^(M-1)-1)+1
其中M是猴子的个数.

程序简化到了极点.

[[it] 本帖最后由 simpley 于 2008-6-14 17:35 编辑 [/it]]
----------------解决方案--------------------------------------------------------
。。
呵呵,是很简化
----------------解决方案--------------------------------------------------------
发现猴子扔掉的桃子数目改变后仍适用本公式:
M*(M^(M-1)-P)+P
M是猴子数,P是猴子扔掉的桃子数,其中P只须小于(M-1)^(M-1)即可.这样可以保证最后的猴子至少能分得1个桃子
----------------解决方案--------------------------------------------------------
还是看不懂
原来的桃子是多少
----------------解决方案--------------------------------------------------------
你测试过没有,如果可以,能发断程序上来不?
----------------解决方案--------------------------------------------------------
没有试过,但肯定不会错
----------------解决方案--------------------------------------------------------
回复 2# learnerboy 的帖子
你测试过没,我测试,有2个错误の
----------------解决方案--------------------------------------------------------
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]交换,结果可想而知。。错误!

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

[[it] 本帖最后由 himpo 于 2008-6-15 09:00 编辑 [/it]]
----------------解决方案--------------------------------------------------------
  相关解决方案