2017-07-14 18:13:35

  • writer:pprp
  • 介绍:最基本用代码展示思想的一道题
  • 题意如下;
  • 他细细观察了自己的工作环境,发现整个工作室是一个N行M列的矩形布局,或者是因为屌丝的本性逐步暴露,他还暗自给每个同事在心里进行了魅力值评分(为区别男女,男生一律用负整数表示,女生一律用正整数表示)。 
      现在,小Q把所有人的数据记录下来,并且这样定义一个位置的价值: 
      1、一个位置的价值只和其上下左右四个邻居的魅力值有关(对于靠边的位置,只考虑其存在的邻居); 
      2、如果某位置的邻居和该位置主人性别不同,则总分加上邻居魅力值的绝对值,否则减去; 
      3、对周围所有邻居的数据处理后,最终的得分即为这个位置的最终得分,得分越高,则该位置越好;

      现在你能帮助小Q计算一下哪里才是最佳位置吗?

    Input输入包含多组测试数据; 
    每组测试数据的第一行包含2个整数N和M,表示工作室的布局是N行M列; 
    接下来的N行,每行有M个整数,分别表示对应位置员工的魅力值数据Ki,正整数表示女生的魅力值,负整数表示男生的魅力值; 
    N和M为0的时候表示输入数据结束。

    TechnicalSpecificationTechnicalSpecification 
    N<=20 
    M<=20 
    -100<=Ki<=100 
    Output请计算并输出最佳位置的行列号以及对应的得分,如果得分最高的位置有多个,则请输出行号最小的那个,行号还相同的话,再比较列号,只输出列号最小的那个即可。 
    Sample Input

    2 3
    5 -4 3
    -6 3 7
    0 0

    Sample Output

    1 2 11
  • #include <iostream>
    #include <cmath> using namespace std; int main()
    {
    int N,M; while(cin >> N >> M && (N!=)&&(M!=))
    {
    int **a = new int* [N+];
    int ** b = new int* [N+]; for(int i = ; i < N+; i++)
    {
    a[i] = new int[M+];
    b[i] = new int[M+];
    } for(int i = ; i <= N+ ; i++)
    {
    for(int j = ; j <= M+ ; j++)
    {
    if(i == || j == ||i == N+ || j == M+)
    {
    a[i][j] = ;
    }
    else
    {
    cin >> a[i][j];
    }
    }
    }
    for(int i = ; i <= N+; i++)
    for(int j = ; j <= M+ ; j++)
    b[i][j] = ; for(int i = ; i <= N; i++)
    {
    for(int j = ; j <= M ; j++)
    {
    int up = a[i-][j],down = a[i+][j],
    left = a[i][j-],right = a[i][j+]; if(a[i][j] > )
    {
    int tmp = ;
    if(up > )
    {
    tmp -= abs(up);
    }
    else
    {
    tmp += abs(up);
    }
    if(down > )
    {
    tmp -= abs(down);
    }
    else
    {
    tmp += abs(down); }
    if(left > )
    {
    tmp -= abs(left);
    }
    else
    {
    tmp += abs(left); }
    if(right > )
    {
    tmp -= abs(right);
    }
    else
    {
    tmp += abs(right);
    }
    b[i][j]=tmp;
    }
    else if(a[i][j] < )
    {
    int tmp = ;
    if(up > )
    {
    tmp += abs(up);
    }
    else
    {
    tmp -= abs(up);
    }
    if(down > )
    {
    tmp += abs(down);
    }
    else
    {
    tmp -= abs(down);
    }
    if(left > )
    {
    tmp += abs(left);
    }
    else
    {
    tmp -= abs(left);
    }
    if(right > )
    {
    tmp += abs(right);
    }
    else
    {
    tmp -= abs(right);
    }
    b[i][j] = tmp;
    }
    else
    return ;
    }
    } int maxcharm = ;
    int tagi,tagj; for(int i = ; i <= N ; i++)
    {
    for(int j = ; j <= M ; j++)
    {
    if(b[i][j] != )
    if(maxcharm < b[i][j])
    {
    tagi = i;
    tagj = j;
    maxcharm = b[i][j];
    }
    }
    } cout << tagi <<" "<< tagj <<" "<<maxcharm<<endl; } return ;
    }

vjudge-A-这是测试你会不会语言的模拟的更多相关文章

  1. Vjudge - B - 这是测试你会不会排序

    2017-07-14 22:44:11 writer:pprp 题目: 他们提出的比赛规则是这样的: 1.  每方派出n个人参赛: 2.  出赛的顺序必须是从弱到强(主要担心中国人擅长的田忌赛马):  ...

  2. 测试c语言函数调用性能因素之测试三

    函数调用:即调用函数调用被调用函数,调用函数压栈,被调用函数执行,调用函数出栈,调用函数继续执行的一个看似简单的过程,系统底层却做了大量操作. 操作: 1,               调用函数帧指针 ...

  3. webdriver高级应用- 测试HTML5语言实现的视频播放器

    能够获取HTML5语言实现的视频播放器,视频文件的地址.时长,控制播放器进行播放或暂停播放等操作. #encoding=utf-8 import unittest from selenium impo ...

  4. 测试Swift语言代码高亮-使用highlight.js

    func &( left:OCBool, right: OCBool)->OCBool{ if left{ return right } else{ return false } }

  5. setlocale()函数测试当前语言的两个程序

    http://www.cnblogs.com/cnyao/archive/2010/05/06/1729220.html setlocale()函数是用来配置地域信息的,原本以为这个也是windows ...

  6. .net单元测试——常用测试方式(异常模拟、返回值测试、参数测试、数据库访问代码测试)

    最近在看.net单元测试艺术,我也喜欢单元测试,今天介绍一下如何测试异常.如何测试返回值.如何测试模拟对象的参数传递.如何测试数据库访问代码.单元测试框架使用的是NUnit,模拟框架使用的是:Rhin ...

  7. 汽车总线obd模拟器,obd仿真器,ecu模拟器,obd开发测试工具,可以模拟ecu中的obd协议 MRD-5050

    汽车总线OBD模拟器MRD-5050型号是在车辆越来越趋于网络化的趋势下研发的,是汽车产品开发.调试.生产必备的工具,能为为开发人员节省大量的时间.当前车辆上的总线设备越来越多,有的高端车上甚至多到有 ...

  8. 【C语言】模拟实现atoi函数

    atoi(表示 ascii to integer)是把字符串转换成整型数的一个函数. atoi()函数会扫描参数 nptr字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过isspace( ...

  9. 【C语言】模拟实现库函数strcat函数

    //模拟实现库函数strcat函数 #include <stdio.h> #include <string.h> #include <assert.h> char ...

随机推荐

  1. 解决kindeidtor与struts2框架交互WARN OgnlValueStack:68 - Error setting value [[Ljava.lang.String;@10da4df]的bug

    当用使用ssh框架,前端用到kindeitor富文本编辑器时候,上传文件后有一个图片管理.当点击图片管理的时候,在后台会报一个异常: WARN OgnlValueStack:68 - Error se ...

  2. centos7通过阿里云配置docker加速镜像

    针对Docker客户端版本大于1.10.0的用户 您可以通过修改daemon配置文件/etc/docker/daemon.json来使用加速器: sudo mkdir -p /etc/docker s ...

  3. 如何实现手游app瘦身?

    手游服务商来说,手游包体大一直是个很困扰的问题.一款手游产品而言,包体大小和更新方式对于有效用户的转化率往往起到非常关键的作用,话说手游安装包越小,用户转化率越高,那该如何实现app瘦身呢? 工具/原 ...

  4. Linux ssh服务

    关于ssh服务不多说就提几句,1,机房的服务器一般都是通过远程连接登录的,远程登录就必然少不了ssh客户端.2,虚拟机每次都要点击进去,每次退出来也需要按Ctrl+Alt+Enter,也比较麻烦,有时 ...

  5. FindBugs——帮助查找隐藏的bug

    FindBugs 1.什么是FindBugs FindBugs 是一个静态分析工具,它检查类或者 JAR 文件,将字节码与一组缺陷模式进行对比以发现可能的问题.有了静态分析工具,就可以在不实际运行程序 ...

  6. 虚拟机——安装虚拟机时,提示intel VT-x处于禁用状态

    1.联想Lenovo扬天T4900C-00安转虚拟机提示: 按F12进入bios模式,修改Intel VT-x为启用,BIOS中依次选择:Advanced(高级)——CPU Configuration ...

  7. SpringMVC的映射器,适配器,控制器

    一.各司其职   (1)HandlerMapping映射器 根据客户端请求的url,找到处理本次请求的处理器,即将请求的路径和controller关联起来 (2)HandlerAdapter适配器 对 ...

  8. KDDCUP CTR预测比赛总结

    赛题与数据介绍 给定查询和用户信息后预测广告点击率 搜索广告是近年来互联网的主流营收来源之一.在搜索广告背后,一个关键技术就是点击率预测-----pCTR(predict the click-thro ...

  9. WEB前端研发工程师编程能力成长之路(2)

    四.[入微] 最强解决方案.你能够走在需求的前面,将当前需求里有的.没有直接提出来的.现在暂时没有但将来可能有的等等,及前端编程潜规则等各个方方面面都综合考虑,给出最优方案.以一招胜万招. var s ...

  10. HDU 1116 Play on Words(欧拉路径(回路))

    http://acm.hdu.edu.cn/showproblem.php?pid=1116 题意:判断n个单词是否可以相连成一条链或一个环,两个单词可以相连的条件是 前一个单词的最后一个字母和后一个 ...