确定指定数据范围内数据个数C语言

来源:互联网 发布:软件开发工程师学习班 编辑:程序博客网 时间:2024/05/16 13:40

  看<<AtA>>,讲计数排序后面的一道习题.确实,睾丸之后,耳朵里面略疼,呵呵.

  指定的数据,在 min ~ max 范围内,确定其中数据在 start ~ end 的数据的个数.因为是计数排序的习题,很自然地想到借助于计数排序解决,或者,是一部分,或者,是变体.其实,这一部,貌似很难.只不过,在那个时刻,理所当然地想到了.

  之后,很快就写好了.写好了的时候, min 只能为 0 . 于是,我就在想,试试负数.结果,一试,试出毛病了.在经过了一段复杂的深度逻辑跟踪之后,发现问题其实很明显, start 不是左边界的时候, 直接用 A[end] - A[start - 1]就可以了.起初的时候,我居然去 "-" 了 A[start].只能说,当时我对计数排序还没理解到哪去,后来,明白了.没有抓住这个算法的特点,或者,根本就是不懂.

  还好吧,现在搞明白了.很庆幸自己当时进一步考虑,才发现了问题.不然,等到面试的时候,出状况,就不好了.自己今后,也要注意.

  总之啦,<<AtA>>真的有必要认真地搞下去,确实啊,这东西,很好.

  好了,贴咯~


原创粉丝点击