• 5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果


    题目

    5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果

    A选手说:B第一,我第三。
    B选手说:我第二,E第四。
    C选手说:我第一,D第二。
    D选手说:C最后,我第三。
    E选手说:我第四,A第一。
    比赛结束后,每位选手都说对了一半,请编程确定比赛的名次。


    初次见到这种题,感觉很难将其抽象出来 用编程来解决它,通过查阅相关文档,终于灵光乍现!现总结思路如下

    通过排列组合知识,可以这样来理解  A B C D E五个人,每个人分别可以有五个位置去 即第一 第二...到第五 5个位置 ,于是这样下来就有5^5种情况。只要在这5^5种情况中找出同时符合题目那五个条件那种情况即可,在怎样编写条件这个地方,我还小小纠结了好一会~~

    代码如下:

     1 #include <stdio.h>
     2 int Over(int arr[])//判断数组内的值是否有重复的
     3 {
     4     int i = 0;
     5     int j = 0;
     6     for (i = 0; i < 5; i++)
     7         for (j = i + 1; j < 5; j++)
     8         {
     9             if (arr[i] == arr[j])
    10                 return 0;
    11         }
    12         return 1;
    13 }
    14 
    15 int main()
    16 {
    17     //数组arr[0]~arr[4]分别代表A B C D E
    18     //arr[i]的值表示其名次 
    19     int arr[5] = { 0 };
    20     for (arr[0] = 1; arr[0] <= 5; ++arr[0])
    21        for (arr[1] = 1; arr[1] <= 5; ++arr[1])
    22            for (arr[2] = 1; arr[2] <= 5; ++arr[2])
    23                for (arr[3] = 1; arr[3] <= 5; ++arr[3])
    24                    for (arr[4] = 1; arr[4] <= 5; ++arr[4]){
    25                     if (  (arr[1] == 2) + (arr[0] == 3) == 1 
    26                        && (arr[1] == 2) + (arr[4] == 4) == 1 
    27                        && (arr[2] == 1) + (arr[3] == 2) == 1 
    28                        && (arr[2] == 5) + (arr[3] == 3) == 1 
    29                        && (arr[4] == 4) + (arr[0] == 1) == 1)
    30                     if (Over(arr)!=0)
    31                        printf("A:%d B:%d C:%d D:%d E:%d
    ", arr[0], arr[1], arr[2], arr[3], arr[4]);
    32                     }
    33     return 0;
    34 } 
    Esh!
  • 相关阅读:
    Syntactic_sugar
    processor, memory, I/O
    he time that it takes to bring a block from disk into main memory
    How MySQL Uses Indexes CREATE INDEX SELECT COUNT(*)
    mysqli_multi_query($link, $wsql)
    UTC ISO 8601
    but this usually doesn’t gain you anything.
    SET GLOBAL slow_query_log=1
    SET GLOBAL long_query_time=0
    a read only variable
  • 原文地址:https://www.cnblogs.com/tp-16b/p/7801004.html
Copyright © 2020-2023  润新知