zoukankan      html  css  js  c++  java
  • C语言练习题_北理工的恶龙

    背景:
    最近,北理工出现了一只恶龙,它长着很多 头,而且还会吐火,它将会把北理工烧成废墟, 于是,校长下令召集全校所有勇士杀死这只恶龙。要杀死这只龙,必须把它所有的头都砍掉,每个勇士只能砍一个龙头,龙的每个头大小都不一样,一个勇士只有在身高不小于龙头的直径的情况下才能砍下它。而且勇士们要求,砍下一个龙头必须得到和自己身高厘米数一样的学分。校长想花 最少的学分数 杀死恶龙,于是找到你寻求帮助。

    输入:

    第一行 龙头数 n , 勇士人数 m ( 1<=n, m<=100 ) 接下来n行,每行包含一个整数,表示龙头的直径,接下来 m 行,每行包含一个整数,表示勇士的身高

    输出:

    如果勇士们能完成任务,输出校长需要花的最小费用;否则输 出 “bit is doomed! ”

     1 #include <stdio.h>
     2 
     3 int main()
     4 {
     5     int i,j,t;
     6     int dragon[105],dragon_f[105];
     7     int warrior[105],warrior_f[105];
     8     int dragon_n,warrior_n;
     9 
    10     scanf("%d %d",&dragon_n,&warrior_n);
    11     for (i=0; i<dragon_n; i++){
    12         scanf("%d",&dragon[i]);
    13     }
    14     for (i=0; i<warrior_n; i++){
    15         scanf("%d",&warrior[i]);
    16     }
    17     for (i=0; i<105; i++){
    18         dragon_f[i] = warrior_f[i] = 0;
    19     }
    20     // sort
    21     for (i=0; i<dragon_n-1; i++){
    22         for (j=0; j<dragon_n-i-1; j++){
    23             if (dragon[j] > dragon[j+1]){
    24                 t = dragon[j+1];
    25                 dragon[j+1] = dragon[j];
    26                 dragon[j] = t;
    27             }
    28         }
    29     }
    30     for (i=0; i<warrior_n-1; i++){
    31         for (j=0; j<warrior_n-i-1; j++){
    32             if (warrior[j] > warrior[j+1]){
    33                 t = warrior[j+1];
    34                 warrior[j+1] = warrior[j];
    35                 warrior[j] = t;
    36             }
    37         }
    38     }
    39 
    40     for (i=0; i<dragon_n; i++){
    41         for (j=0; j<warrior_n; j++){
    42             if (dragon[i] <= warrior[j] && dragon_f[i] == 0 && warrior_f[j] == 0){
    43                 dragon_f[i] = 1;
    44                 warrior_f[j] = 1;
    45             }
    46         }
    47     }
    48     for (i=0; i<dragon_n; i++){
    49         if (dragon_f[i] == 0){
    50             printf("bit is doomed!
    ");
    51             return 0;
    52         }
    53     }
    54     int sum = 0;
    55     for (i=0; i<warrior_n; i++){
    56         if (warrior_f[i] == 1){
    57             sum = sum + warrior[i];
    58         }
    59     }
    60     printf("%d
    ",sum);
    61     return 0;
    62 }
  • 相关阅读:
    【python】【pycharm】+python工程打包成exe+在windows下自动定时运行
    技术备忘
    【Linux】—常用命令(测试人员)
    【python】【pycharm】+pip解析
    【python】【pycharm】+封装&导入
    C# 之程序退出的方法
    C# 之值类型和引用类型
    C# 之数组
    找靓机AppUI自动化测试延伸
    初、中、高级程序员的区别有哪些?
  • 原文地址:https://www.cnblogs.com/raul-ac/p/3402030.html
Copyright © 2011-2022 走看看