vjudge-A-这是测试你会不会语言的模拟
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 Input2 3 
 5 -4 3
 -6 3 7
 0 0Sample 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-这是测试你会不会语言的模拟的更多相关文章
- Vjudge - B - 这是测试你会不会排序
		2017-07-14 22:44:11 writer:pprp 题目: 他们提出的比赛规则是这样的: 1. 每方派出n个人参赛: 2. 出赛的顺序必须是从弱到强(主要担心中国人擅长的田忌赛马): ... 
- 测试c语言函数调用性能因素之测试三
		函数调用:即调用函数调用被调用函数,调用函数压栈,被调用函数执行,调用函数出栈,调用函数继续执行的一个看似简单的过程,系统底层却做了大量操作. 操作: 1, 调用函数帧指针 ... 
- webdriver高级应用- 测试HTML5语言实现的视频播放器
		能够获取HTML5语言实现的视频播放器,视频文件的地址.时长,控制播放器进行播放或暂停播放等操作. #encoding=utf-8 import unittest from selenium impo ... 
- 测试Swift语言代码高亮-使用highlight.js
		func &( left:OCBool, right: OCBool)->OCBool{ if left{ return right } else{ return false } } 
- setlocale()函数测试当前语言的两个程序
		http://www.cnblogs.com/cnyao/archive/2010/05/06/1729220.html setlocale()函数是用来配置地域信息的,原本以为这个也是windows ... 
- .net单元测试——常用测试方式(异常模拟、返回值测试、参数测试、数据库访问代码测试)
		最近在看.net单元测试艺术,我也喜欢单元测试,今天介绍一下如何测试异常.如何测试返回值.如何测试模拟对象的参数传递.如何测试数据库访问代码.单元测试框架使用的是NUnit,模拟框架使用的是:Rhin ... 
- 汽车总线obd模拟器,obd仿真器,ecu模拟器,obd开发测试工具,可以模拟ecu中的obd协议 MRD-5050
		汽车总线OBD模拟器MRD-5050型号是在车辆越来越趋于网络化的趋势下研发的,是汽车产品开发.调试.生产必备的工具,能为为开发人员节省大量的时间.当前车辆上的总线设备越来越多,有的高端车上甚至多到有 ... 
- 【C语言】模拟实现atoi函数
		atoi(表示 ascii to integer)是把字符串转换成整型数的一个函数. atoi()函数会扫描参数 nptr字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过isspace( ... 
- 【C语言】模拟实现库函数strcat函数
		//模拟实现库函数strcat函数 #include <stdio.h> #include <string.h> #include <assert.h> char ... 
随机推荐
- Python 之RabbitMQ使用
			1. IO 多路复用 # select 模拟socket server # server 端 import select import socket import sys import queue s ... 
- java基础03变量和基本数据类型
			package cn.bdqn.test; /** * * @author 小豆腐 * * 变量:会变化的量?? * 一个数据在内存中存储空间的表示!在运行期间可以动态改变! * * 关键字:在jav ... 
- Appium+python移动端自动化测试-环境搭建(一)
			搭建所在系统环境:Windows7版本64位系统 一.环境准备 jdk8.0.151 android-sdk_r20.3.4-windows python3.5 appium1.4.16.1 Node ... 
- sigmoid & softmax、cross-entropy、relu
			sigmoid函数由于其自身特点,容易造成几个问题 1.当sigmoid在输出层时容易造成loss较大时学习速度慢的情况(或者说是代价函数学习速度衰退问题) 原因:神经网络的学习方式是通过求代价函数对 ... 
- Linux下的内核抢占
			2017-03-03 很遗憾之前在介绍进程调度的文章中,虽然涉及到了内核抢占,但是却没有对其进行深入介绍,今天就稍微总结下内核抢占. 内核抢占在一定程度上减少了对某种事件的响应延迟,这也是内核抢占被引 ... 
- ovn-architecture 摘要
			OVN架构图如下所示: 1.OVN Southbound Database由以下三种数据构成: Physical Network(PN)table用于确定如何到达hypervisor以及其他node ... 
- uchome client.php
			uchome 主要使用了php的call_user_func()函数,在uc_clinet/client.php中,一般指向uc_api_mysql,而 uc_api_mysql()函数 则负责分发到 ... 
- 007-Hadoop Hive sql语法详解2-修改表结构
			一.表 更改表名:ALTER TABLE table_name RENAME TO new_table_name 增加表的元数据信息:ALTER TABLE table_name SET TBLPRO ... 
- ui-select : There is no "X"(delete button) with selectize theme, when allow-clear="true"
			but add allow-clear="true"For Bootstrap and Select2 themes, it's working perfectly. reason ... 
- one hot coding -机器学习
			机器学习 数据预处理之独热编码(One-Hot Encoding) 问题由来 在很多机器学习任务中,特征并不总是连续值,而有可能是分类值. 例如,考虑一下的三个特征: ["male" ... 
