谁家孩子跑的最慢c语言中文网,C语言谁家孩子跑得最慢

这篇博客讲述了在一次包含张、王、李三家九个孩子的短跑比赛中,通过数学逻辑和编程解决名次排列问题的过程。每个家庭的孩子总分相同,第一名和第二名已被确定,通过排除法和条件判断,使用C++编程得出最后一名是王家的孩子。此实例展示了如何运用算法思维解决实际问题。
摘要由CSDN通过智能技术生成

张、王、李三家各有三个小孩。一天,三家的九个孩子在一起比赛短跑,规定不分年龄大小,跑第一得 9 分,跑第二得 8 分,依次类推。比赛结果显示各家的总分相同,且这些孩子没有同时到达终点的,也没有一家的两个或三个孩子获得相连的名次。已知获第一名的是李家的孩子,获第二名的是王家的孩子。获得最后一名的是谁家的孩子?

算法思想

按题目的条件,共有 1+2+3+…+9=45 分,每家孩子的得分应为 15 分。根据题意可知,获第一名的是李家的孩子,获第二名的是王家的孩子,则可推出:获第三名的一定是张家的孩子。由“这些孩子没有同时到达终点的”可知:名次不能并列,由“没有一家的两个或三个孩子获得相连的名次”可知:第四名不能是张家的孩子。

程序代码

#include

int score[4][4];

int main()

{

int i,j,k,who;

score[1][1]=7;

score[2][1]=8;

score[3][1]=9;

for(i=4;i<6;i++)

for(j=4;j<7;j++)

for(k=4;i!=j&&k<7;k++)

if(k!=i&&k!=j&&15-i-score[1][1]!=15-j-score[2][1]

&&15-i-score[1][1]!=15-k-score[3][1]

&&15-j-score[2][1]!=15-k-score[3][1])

{

score[1][2]=i;score[1][3]=15-i-7;

score[2][2]=j;score[2][3]=15-j-8;

score[3][2]=k;score[3][3]=15-k-9;

}

for(who=0,i=1;i<=3;i++,printf("\n"))

for(j=1;j<=3;j++)

{

printf("%d",score[i][j]);

if(score[i][j]==1)

who=i;

}

if(who==1)

printf("最后一名是张家孩子\n");

else if(who==2)

printf("最后一名是王家孩子\n");

else

printf("最后一名是李家孩子\n");

return 0;

}

调试运行结果

根据算法思想,通过程序的运行得到结果如下所示:

753

861

942

最后一名是王家孩子

总结

本实例主要运用了二维数组的引用和循环的嵌套。二维数组元素的引用形式为“数组名[下标1][下标2]”。例如“a[1][2]”其下标是可以大于或者等于 0 的整型常量、整型变量或者整型表达式。

引用二维数组元素时,下标不要越界,也就是说下标值需要从 0 开始,但不要超过行、列的范围。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值