标题:实在想不通,大家帮忙看看,急
只看楼主
世界模型
Rank: 4
等 级:业余侠客
威 望:1
帖 子:240
专家分:226
注 册:2010-9-12
结帖率:97.44%
已结贴  问题点数:20 回复次数:17 
实在想不通,大家帮忙看看,急
有12个铁球,目前知道里面有一只球的重量与其它的不同,要求只用3次比较找出该球。注意,该球究竟是比其他球重还是轻是未知的。
请编程序实现该问题。
2011-03-18 23:26
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
得分:10 
楼主的问题跟这个差不多。 参考一下吧。
https://bbs.bccn.net/viewthread.php?tid=333089&page=1#pid1919571

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-03-19 09:11
诸葛修勤
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:11
帖 子:549
专家分:1955
注 册:2010-10-28
得分:10 
哪儿的题?
2011-03-19 10:13
诸葛修勤
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:11
帖 子:549
专家分:1955
注 册:2010-10-28
得分:0 
3.25次
2011-03-19 10:16
世界模型
Rank: 4
等 级:业余侠客
威 望:1
帖 子:240
专家分:226
注 册:2010-9-12
得分:0 
我们老大给我们出的测试题
2011-03-19 11:51
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
得分:0 
dp.

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2011-03-19 12:00
诸葛修勤
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:11
帖 子:549
专家分:1955
注 册:2010-10-28
得分:0 
回复 6楼 卧龙孔明
什么意思啊
2011-03-19 12:16
诸葛修勤
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:11
帖 子:549
专家分:1955
注 册:2010-10-28
得分:0 
程序代码:
/*

 *有12个铁球,目前知道里面有一只球的重量与其它的不同,要求只用3次比较找出该球。

 *注意,该球究竟是比其他球重还是轻是未知的。请编程序实现该问题。

 */
#include <stdio.h>

#define    LENGTH    12//数组的长度

int test[LENGTH+1] = {0};

int Compare_to_two(int unkown_x, int unkown_y, int standard_z);
int Compare_array(int dim_x, int dim_y, int num);
void Find_error();
bool Check_array();
void Get_input();
void Show_different_ball( int unkown_x, int unkown_y, int standard_z);

int main()
{
    bool flag = false;

    while ( !flag )
    {
        Get_input();
        flag = Check_array();
    }

    Find_error();

    return 0;
}
/*

 *从控制台输入12个数

 */
void Get_input()
{
    int i = 1;
    printf("\t从控制台输入11个相同的数和1个不同的数以空格隔开\n");
    while( LENGTH+1 != i )
    {
        scanf("%d", test+i);
        ++i;
    }

    return;
}
/*

 *检查输入是否合格 合格则返回true 否则false

 */
bool Check_array()
{
    int i = 2, same_count = 0, different_count = 0;
    while ( LENGTH+1 != i )
    {
        if( test[1] == test[i] )
        {
            ++same_count;
        }
        else
        {
            ++different_count;
        }
        ++i;
    }
    if( (10 == same_count && 1 == different_count) || (0 == same_count && 11 == different_count) )
    {
        return true;
    }
    return false;
}

/*

 *从12个球中查找有问题的那个并取出来

 */
void Find_error()
{
    //{1,2,3,4}{5,6,7,8}{9,10,11,12}
    int result = Compare_array( 1, 5, 4 );
    int sub_result;
    int sum_1 = test[1] + test[6] + test[7];
    int sum_2 = test[2] + test[8] + test[9];

    if( 0 == result )
    {//表示{1,2,3,4}=={5,6,7,8} 问题存在于{9,10,11,12}
        sub_result = Compare_to_two( 9, 10, 1 );
        if( 0 == sub_result )
        {//问题在 11 12 中
            Show_different_ball( 11, 12, 1 );
        }
        else//( -1 == sub_result )
        {//问题在9 10 中
            Show_different_ball( 9, 10, 1 );
        }
        return;
    }
    else if( -1 == result )
    {//表示{9,10,11,12} 是标准的 问题在比较的两组当中的一组中
        //{1,2,3,4}        {5,6,7,8}把3,4,5拿掉
        //{1,2}    {6,7,8}        2和6,7调换
        //{1, 6, 7} {2, 8} 把9放进去
        //{1, 6, 7} {2, 8, 9}
        if( sum_1 == sum_2 )
        {//问题在于 3 4 5
            if( test[3] == test[4] )
            {//5不同
                printf("\t第5号球与其他不同\n");
            }
            else if( test[3] > test[4] )
            {
                printf("\t第3号球与其他不同\n");
            }
            else
            {
                printf("\t第4号球与其他不同\n");
            }
            return;
        }
        else if( sum_1 < sum_2 )
        {//问题在于交换的那些中2, 6, 7
            if( test[6] == test[7] )
            {
                printf("\t第2号球与其他不同\n");
            }
            else if( test[6] > test[7] )
            {
                printf("\t第7号球与其他不同\n");
            }
            else
            {
                printf("\t第6号球与其他不同\n");
            }
        }
        else
        {//问题在1, 8
            if( test[1] == test[9] )
            {
                printf("\t第8号球与其他不同\n");
            }
            else
            {
                printf("\t第1号球与其他不同\n");
            }
        }

    }
    else
    {//表示{9,10,11,12} 是标准的 问题在比较的两组当中的一组中
        if( sum_1 == sum_2 )
        {//问题在于 3 4 5
            if( test[3] == test[4] )
            {//5不同
                printf("\t第5号球与其他不同\n");
            }
            else if( test[3] < test[4] )
            {
                printf("\t第3号球与其他不同\n");
            }
            else
            {
                printf("\t第4号球与其他不同\n");
            }
            return;
        }
        else if( sum_1 < sum_2 )
        {//问题在1, 8
            if( test[1] == test[9] )
            {
                printf("\t第8号球与其他不同\n");
            }
            else
            {
                printf("\t第1号球与其他不同\n");
            }
        }
        else
        {//问题在于交换的那些中2, 6, 7
            if( test[6] == test[7] )
            {
                printf("\t第2号球与其他不同\n");
            }
            else if( test[6] < test[7] )
            {
                printf("\t第7号球与其他不同\n");
            }
            else
            {
                printf("\t第6号球与其他不同\n");
            }
        }

    }
    return;
}
/*

 *比较两个数组的大小 相等返回 0, 左边的大 -1, 右边的大1

 */
int Compare_array(int dim_x, int dim_y, int num)
{
    int sum_x = 0;//存放总值dim_x
    int sum_y = 0;//存放总值dim_y
    int index = 0;
    while( num != index )
    {
        sum_x += test[dim_x + index];
        ++index;
    }
    index = 0;
    while( num != index )
    {
        sum_y += test[dim_y + index];
        ++index;
    }

    if( sum_x == sum_y )
    {
        return 0;
    }
    else if( sum_x > sum_y )
    {
        return -1;
    }
    else
    {
        return 1;
    }   
}
/*

 *两个球未知球  和 两个标准求相比较

 *相等返回0 未知重返回-1 标准重返回1

 */
int Compare_to_two(int unkown_x, int unkown_y, int standard_z)
{
    int xy = test[unkown_x] + test[unkown_y];
    if( xy == 2*standard_z )
    {
        return 0;
    }
    else if( xy > 2*standard_z )
    {
        return -1;
    }
    else
    {
        return 1;
    }
}
/*

 *输出两个球中 有问题的那个球出来

 */
void Show_different_ball( int unkown_x, int unkown_y, int standard_z)
{
    if( test[unkown_x] == test[standard_z] )
    {
        printf("\t第%d号球与其他不同\n", unkown_y);
        return;
    }
    else
    {
        printf("\t第%d号球与其他不同\n", unkown_x);
        return;
    }
}
2011-03-20 11:04
世界模型
Rank: 4
等 级:业余侠客
威 望:1
帖 子:240
专家分:226
注 册:2010-9-12
得分:0 
貌似10号球之后有问题的球都会显示是:第10号球有问题
2011-03-20 18:44
诸葛修勤
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:11
帖 子:549
专家分:1955
注 册:2010-10-28
得分:0 
回复 9楼 世界模型
你截个图看下  我这里没有你说的情况
2011-03-20 21:20



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-334102-1-1.html




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

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