Given an array of n integers and q queries. Write a program to print floor value of mean in range l to r for each query in a new line.

Examples:
Input : arr[] = {1, 2, 3, 4, 5}
        q = 3
        0 2
        1 3
        0 4
Output : 2
         3
         3
Here for 0 to 2 (1 + 2 + 3) / 3 = 2

Input : arr[] = {6, 7, 8, 10}
        q = 2
        0 3
        1 2
Output : 7
         7

Input:

The first line consists of an integer T i.e number of test cases.

The first line of each test case consists of two integer n and q.

The next line consists of n spaced integers. The next line consists of 2*k spaced integers each pair representing the range.

Output:
Print the mean(floor value) in given range for each query in new line.

Constraints: 
1<=T<=100
1<=q<n<=1000
1<=a[i]<=1000

Example:
Input:
1
5 3
1 2 3 4 5
0 2 1 3 0 4

Output:
2 3 3

下面是我的代码实现:

#include <stdio.h>

int main() {
    int num,i;//测试用例
    scanf("%d\n",&num);

    for(i=0;i<num;i++)
    {
        int N,M,j;

        scanf("%d",&N);
        scanf("%d",&M);
        int *Arr=(int *)malloc(sizeof(int)*N);
        int *Brr=(int *)malloc(sizeof(int)*2*M);
        for(j=0;j<N;j++)//依次输入数组元素
            scanf("%d",&Arr[j]);

        for(j=0;j<2*M;j++)//依次输入"测试对"的值
            scanf("%d",&Brr[j]);

        for(j=0;j<M;j++)//循环求解平均值
        {
          int avg=0,sum=0,k;
          for(k=Brr[2*j];k<=Brr[2*j+1];k++)
          {
              sum=sum+Arr[k];//求和
          }
          avg=sum/(Brr[2*j+1]-Brr[2*j]+1);//平均值=和/元素个数。
          printf("%d ",avg);
        }
    }
    return 0;
}

 然后提交的时候,出现的问题是:

Wrong Answer. !!!Wrong Answer
Possibly your code doesn't work correctly for multiple test-cases (TCs).
The first test case where your code failed:

Input:
42 30
335 501 170 725 479 359 963 465 706 146 282 828 962 492 996 943 828 437 392 605 903 154 293 383 422 717 719 896 448 727 772 539 870 913 668 300 36 895 704 812 323 334
2 33 21 25 22 29 8 11 28 39 3 7 29 39 19 22 10 11 14 36 34 36 10 38 10 28 20 33 9 14 10 20 12 21 20 33 15 23 4 18 24 38 10 26 16 29 15 18 14 25 34 35 24 32 35 39 3 35 6 19

Its Correct output is:
610 393 575 490 640 598 657 488 555 607 334 624 615 625 617 697 671 625 548 618 641 609 566 650 589 484 678 549 616 646

And Your Code's output is:
610 393 575 490 640 598 657 488 555 607 334 624 615 625 617 697 671 625 548 618 641 609 566 650 589 484 678 549 616 646 434 499 485 480 447 559 426 455 482 494 501 511 4...

  截图如下:

这是为什么我的代码会多输出这么多数据呢?我很不理解。。。。

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++问题已经解决++++++分割线+++++问题已经解决++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

现在已经理解了我之前的错误。

这个程序,在Code Blocks里面的输出是正常的,截图如下:

正确的输出是因为我在输入案例中只输入了一个,程序员自己可以控制格式。

但是为什么在geeksforgeeks就会出错呢?

是因为当它评判的时候,是将输出放在一个文件里面,然后通过对比我的程序的输出文件和它正确的文件,如果一致就通过,如果不一致,就是wrong answer!!!。并且它的评判应该是多个测试用例,每一个测试用例是通过换行进行分割的。我的程序中没有在每一个测试用例结束时候通过换行进行分割。,所以,增加了每一个测试用例结束时候的换行,就解决了这个问题。

这个题目我稍微理解了一些OJ的评判方法。多加练习才是。

现在的代码更新如下:

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int num,i;//测试用例
    scanf("%d\n",&num);

    for(i=0;i<num;i++)
    {
        int N,M,j;

        scanf("%d",&N);
        scanf("%d",&M);
        int *Arr=(int *)malloc(sizeof(int)*N);
        int *Brr=(int *)malloc(sizeof(int)*2*M);
        for(j=0;j<N;j++)//依次输入数组元素
            scanf("%d",&Arr[j]);

        for(j=0;j<2*M;j++)//依次输入"测试对"的值
            scanf("%d",&Brr[j]);

        for(j=0;j<M;j++)//循环求解平均值
        {
          int avg=0,sum=0,k;
          for(k=Brr[2*j];k<=Brr[2*j+1];k++)
          {
              sum=sum+Arr[k];//求和
          }
          avg=sum/(Brr[2*j+1]-Brr[2*j]+1);//平均值=和/元素个数。
          printf("%d ",avg);
        }
        printf("\n");
    }
    return 0;
}

  还有一种更简单的方案,如下:就是使用变量进行计算和,然后求平均值。相比之前的程序,节省了存储空间。

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int num,i;
    scanf("%d",&num);
    for(i=0;i<num;i++)
    {
        int N,M,j;//N是数组元素个数,M是测试对。j循环变量
        scanf("%d",&N);
        scanf("%d",&M);
        int *Arr=(int *)malloc(sizeof(int)*N);
        for(j=0;j<N;j++)
            scanf("%d",&Arr[j]);
        int left, right,k;//left和right是范围变量,k是循环变量,sum是当前和。
        int *result=(int *)malloc(sizeof(int)*M);//存放结果。
        for(j=0;j<M;j++)
        {
            scanf("%d",&left);
            scanf("%d",&right);
            int sum=0;
            for(k=left;k<=right;k++)
            {
                sum=sum+Arr[k];
            }
            result[j]=sum/(right-left+1);
        }
        for(j=0;j<M;j++)
            printf("%d ",result[j]);
    }
    return 0;
}

  如有疑问,请留言。

[Mean of range in array]的更多相关文章

  1. 【VBA】利用Range声明Array(一维/二维)

    [说明] B2开始到B?(中间不能有空格),定义一维数组Arr_approver() Dim R_sh As Worksheet Set R_sh = ThisWorkbook.Sheets(&quo ...

  2. 转 python range 用法

    详细记录python的range()函数用法   使用python的人都知道range()函数很方便,今天再用到他的时候发现了很多以前看到过但是忘记的细节.这里记录一下range(),复习下list的 ...

  3. 详细记录python的range()函数用法

    使用python的人都知道range()函数很方便,今天再用到他的时候发现了很多以前看到过但是忘记的细节.这里记录一下range(),复习下list的slide,最后分析一个好玩儿的冒泡程序. 这里记 ...

  4. range,shuffle,str_shuffle

    print_r(range(1,20)); 输出,range产生 Array( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 ...

  5. iOS 判断数组array中是否包含元素a,取出a在array中的下标+数组方法详解

    目前找到来4个解决办法,第三个尤为简单方便 NSArray * arr = @["]; //是否包含 "]) { NSInteger index = [arr indexOfObj ...

  6. python 内置函数range和xrange

    range range 是一种类型(type),它是一个数字的序列,而且是不可变的,通常用在for循环中. class range(stop)class range(start, stop [, st ...

  7. python中的range与xrange

    range 也是一种类型(type),它是一个数字的序列(s sequence of numbers),而且是不可变的,通常用在for循环中. class range(stop) class rang ...

  8. (转)python的range()函数用法

    使用python的人都知道range()函数很方便,今天再用到他的时候发现了很多以前看到过但是忘记的细节.这里记录一下range(),复习下list的slide,最后分析一个好玩儿的冒泡程序. 转自: ...

  9. range() 函数详解 python

    使用python的人都知道range()函数很方便,今天再用到他的时候发现了很多以前看到过但是忘记的细节.这里记录一下range(),复习下list的slide,最后分析一个好玩儿的冒泡程序. 这里记 ...

随机推荐

  1. c语言的内存分析

    1. 进制 1. 什么是进制 ● 是一种计数的方式,数值的表示形式  汉字:十一   十进制:11  二进制:1011  八进制:13 ● 多种进制:十进制.二进制.八进制.十六进制.也就是说,同一个 ...

  2. Python——Scrapy初学

    Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架.可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中.Scrapy最初是为了页面抓取(更确切来说, 网络抓取)所设计的,也 ...

  3. web兼容性测试相关知识

    一.客户端兼容性 1.浏览器的兼容性测试 a.内核角度 Tridnt内核:代表作IE.腾讯.遨游.世界之窗等 Gecko内核:代表作Firefox webkit内核:代表作Safari.Chrome ...

  4. Java基础(二)-static关键字分析

    static关键字是我们在编程中经常会使用到的,但有些可能只知其然而不知其所以然.下面介绍static关键字的作用再通过例子结合说明. static关键字共有五种作用(先说明static所修饰的不会改 ...

  5. Webpack3.0入门指南

    前言 本文是基于我厂基友的Webpack学习系列(一)初学者使用教程 这篇文章做构建.可能基友的文章是基于Mac环境,我是windows环境,在学习时遇到了很多坑,询问基友,他让我搞个基于window ...

  6. javascript中break,continue和return语句用法小结:

    Break语句会使程序立刻退出包含在最底层的循环或者退出一个switch语句,它是用来退出循环或者switch语句. 例如: <script type="text/javascript ...

  7. jQuery noConflict() 方法----与其他javaScript插件冲突时

    1,全名代替----jQuery: $.noConflict(); jQuery(document).ready(function(){ jQuery("button").clic ...

  8. linux系统下安装配置解压版的MySQL数据库

    一.解压文件到当前目录 命令:tar -zxvf mysql....tar.gz 二.移动解压完成的文件夹到目标目录并更名mysql 命令:mv mysql-版本号 /usr/local/mysql ...

  9. C#中如何使用断点操作调试程序

    Visual Studio调试器调试 当代码不能正常运行时,可以通过调试定位错误.常用的程序调试操作包括设置断点.开始.中断和停止程序的执行.单步执行程序以及使程序运行到指定的位置.下面将对这几种常用 ...

  10. node.js第二天之模块

    一.模块的定义 1.在Node.js中,以模块为单位划分所有功能,并且提供了一个完整的模块加载机制,这时的我们可以将应用程序划分为各个不同的部分. 2.狭义的说,每一个JavaScript文件都是一个 ...