题面:输入一列整数,输出它们的总和、最大值、最小值、并从大到小输出。

先上一波伪代码,认真地做一波数组排序题。

#include<stdio.h>
#include<math.h>
] , b[];
int main ()
{
     , min = pow( , ) -  , max = -pow(,);
    scanf("%d",&a);
     ; i <= a ; i ++)
    {
        scanf("%d",&c[i]);
        sum += c[i];
        if(c[i] > max)
            max = c[i] ;
        if(c[i] < min)
            min = c[i] ;
        //先统计不重复的个数,记为An 。
        //桶排序,或者冒泡排序进行排序,注意重复的值,放到这个数组b中。
         ;
    }
    printf("%d\n%d\n",max,min);
     ; k <= /*An*/; k ++ )
        printf("%d\n",b[k]);
     ;
}

伪代码

不知道有没有把这个题做复杂,总之在啥都不会的情况下,第一个想到的是桶排序,然而只会冒泡排序的部分。

//一会专门开一个随笔写写自己对于那些排序的理解与想法。

很皮,在研究一番桶排序之后,发现桶排序,就是将值放到另一个数组对应的值的数组位数上面去,b[c[i]] = 1,如果需要多次输入,改成b[c[i]] ++即可。

于是很兴奋地试了样例,过了,交上去,果断WA了,尬的一批。

 #include<stdio.h>
 #include<math.h>
 ] , b[];
 int main ()
 {
      , min = pow( , ) -  , max = -pow(,);
     scanf("%d",&a);
      ; i <= a ; i ++)
     {
         scanf("%d",&c[i]);
         sum += c[i];
         if(c[i] > max)
             max = c[i] ;
         if(c[i] < min)
             min = c[i] ;
         b[c[i]]  =  ;
     }
     printf("%d\n%d\n%d\n%d\n",sum,max,min,max);
      ; j -- )
          ; k < b[j]; k ++ )
             printf("%d\n",j);
      ;
 }

第一次交

于是观察到了一个奇葩的值

10  9 9 9 9 9 9 9 9 9 9

在我的第一个桶排序中,很迷地输出不了最大值,于是在for循环前加了一个最大值,导致这组值输出的多了一个9。问题不大,在外层循环的地方扩到了最大,很愉快地过了。

 #include<stdio.h>
 #include<math.h>
 ] , b[];
 int main ()
 {
      , min = pow( , ) -  , max = -pow(,);
     scanf("%d",&a);
      ; i <= a ; i ++)
     {
         scanf("%d",&c[i]);
         sum += c[i];
         if(c[i] > max)
             max = c[i] ;
         if(c[i] < min)
             min = c[i] ;
         b[c[i]]  =  ;
     }
     printf("%d\n%d\n%d\n",sum,max,min);
      ; j >=  ; j -- )
          ; k < b[j]; k ++ )
             printf("%d\n",j);
      ;
 }

但是最后还是WA了一个点,因为500太小了,测试点有一个是5058,就没有输出。

最终完成代码

 #include<stdio.h>
 #include<math.h>
 ] , b[];
 int main ()
 {
      , min = pow( , ) -  , max = -pow(,);
     scanf("%d",&a);
      ; i <= a ; i ++)
     {
         scanf("%d",&c[i]);
         sum += c[i];
         if(c[i] > max)
             max = c[i] ;
         if(c[i] < min)
             min = c[i] ;
         b[c[i]]  =  ;
     }
     printf("%d\n%d\n%d\n",sum,max,min);
      ; j >=  ; j -- )
          ; k < b[j]; k ++ )
             printf("%d\n",j);
      ;
 }

AC代码

ps:我觉得我的代码不丑吧,虽然在算法方面很颓,但是还是算得上工整好看的吧。

复习了桶排序,近40分钟才A了这么一道题,尬。

那是我愿意付诸一生的人,现在却没法拥有。

作死上CODEVS,青铜题的更多相关文章

  1. codevs 搜索题汇总(青铜+白银级)

    1792 分解质因数  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 青铜 Bronze   题目描述 Description 编写一个把整数N分解为质因数乘积的程序. 输入描 ...

  2. 用python做oj上的简单题(持续更新中.......)

    本人刚開始接触python,在oj上解一些简单的题,欢迎交流,不喜勿喷. OJ地址链接:acm.sdut.edu.cn http://acm.sdut.edu.cn/sdutoj/showproble ...

  3. hdoj上的一题和程序设计第二次作业的拓展-人见人爱a+b

    hdoj上一道有意思的题目,题目: 人见人爱a+b 敲的也蛮快的,大概十分钟左右就AC了.代码如下: 人见人爱a+b #include<stdio.h> int main() { int ...

  4. 2018 ACM-ICPC 中国大学生程序设计竞赛线上赛 H题 Rock Paper Scissors Lizard Spock.(FFT字符串匹配)

    2018 ACM-ICPC 中国大学生程序设计竞赛线上赛:https://www.jisuanke.com/contest/1227 题目链接:https://nanti.jisuanke.com/t ...

  5. 2018 ACM-ICPC 中国大学生程序设计竞赛线上赛 F题 Clever King(最小割)

    2018 ACM-ICPC 中国大学生程序设计竞赛线上赛:https://www.jisuanke.com/contest/1227 题目链接:https://nanti.jisuanke.com/t ...

  6. 网络流 24 题汇总(LOJ 上只有 22 题???)

    太裸的我就不放代码了...(黑体字序号的题表示值得注意) 1.搭配飞行员 [LOJ#6000] 二分图最大匹配. 2.太空飞行计划 [LOJ#6001] 最小割常规套路.输出方案.(注:这题换行符要用 ...

  7. 上POJ刷题

    Online Judge系统      Online Judge系统(简称OJ)是一个在线的判题系统.用户可以在线提交给定问题的多种程序(如C.C++.Pascal.Java)源代码,系统对源代码进行 ...

  8. codevs 搜索题汇总(钻石+大师级)

    1043 方格取数 2000年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题目描述 Description 设有N*N的方格图 ...

  9. codevs 搜索题汇总(黄金级)

    2801 LOL-盖伦的蹲草计划  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 黄金 Gold   题目描述 Description 众所周知,LOL这款伟大的游戏,有个叫盖 ...

随机推荐

  1. Gridview 重建表头/单击单元格弹出对话框/改变单元格背景色

    整理工作~ 完整的代码在GitHub上, 路径: 项目背景:追踪某个issue,并且记录每天的状态. 要求:1.点击日期就能更改,并且用颜色标志不同的状态 2.增加按钮可关闭issue 3.布局要求日 ...

  2. TIME_WAIT问题总结

         最近用http_load做压测,跑出来一大串"Cannot assign requested address "的错误,查了一下,是TIME_WAIT过多导致的.因为短时 ...

  3. 10分钟精通SharePoint - SharePoint拓扑结构

    SharePoint服务器角色:前端,应用程序和数据库服务器 应用程序服务:搜索.Office文档.User Profile和App等应用服务器 数据库类型:内容数据库.应用程序数据库和配置数据库 规 ...

  4. mybatis对java自定义注解的使用——入门篇

    最近在学习spring和ibatis框架. 以前在天猫实习时做过的一个小项目用到的mybatis,在其使用过程中,不加思索的用了比较原始的一种持久化方式: 在一个包中写一个DAO的接口,在另一个包里面 ...

  5. 老司机实战Windows Server Docker:2 docker化现有iis应用的正确姿势

    前言 上一篇老司机实战Windows Server Docker:1 初体验之各种填坑介绍了安装docker服务过程中的一些小坑.这一篇,我们来填一些稍大一些的坑:如何docker化一个现有的iis应 ...

  6. [Oracle]同义词(synonym)

    (一)同义词的概念 同义词是数据库中表.视图.索引或其他模式对象的别名,与视图相似,同义词不占用实际的存储空间,在数据字典中只存同义词的定义. 在开发数据库时,应尽量避免直接引用表.视图或其他数据库对 ...

  7. 一种类似Retrofit声明接口即可实现调用的WebApi客户端框架

    为.Net出力 java有okhttp,还在okhttp这上搞了一个retrofit,.net有HttpClient,但目前我没有发现有类似的retrofit框架.最近在搞mqtt的webApi封装, ...

  8. Weblogic+apache多虚拟主机

    p.MsoNormal,li.MsoNormal,div.MsoNormal { margin: 0cm; margin-bottom: .0001pt; text-align: justify; f ...

  9. Struts2的类型转换(上)

    传统的类型转换.(略) Struts2中提供了内置的基本的类型转换器,可以实现基本类型的自动转换,包括: Integer, Float, Double, Decimal Date and Dateti ...

  10. 树莓派Raspberry中成功安装RobotFramework+Selenium

    [原创链接]:http://www.cnblogs.com/atsats/p/6666848.html 一般RobotFramework都是安装在Windows/Linux的PC机上,这里将简单介绍在 ...