遥 控 器

acm.zznu.edu.cn/problem.php?id=1617

 

遥 控 器

时间限制: 1 Sec  内存限制: 128 MB
提交: 25  解决: 9
[提交][状态]

题目描述

Dr.Kong 有一台高级电视机,这台电视机可以接受100个频道(从0到99编号)。电视的配套遥控器有13个按钮:

1   2   3   ↑

4   5   6   ↓

7   8   9

—  0

当按"↑"键时,当前频道编号会增加1(如果当前为99频道,则会切换到0频道)。如果按"↓"键,当前频道编号会减小1(如果当前为0频道,则会切换到99频道)。当要切换到0~9频道时,可以直接在遥控器上按相应的键。当要切换到10~99频道时,可以先按"—"键,然后按2个与频道编号相对应的数字键(即先按与频道编号的十位数字相对应的键,然后按与个位数字相对应的键)。

由于遥控器长时间的使用和某些未知原因,遥控器上的某些键已经坏了,不能再起作用了。现在你的任务是,能否告诉Dr.Kong,如何用最少的按键次数来将频道从编号X切换到编号Y。

输入

第一行: N  表示有N组测试数据。  (1<=N<=5)

对每组测试数据有5行,前4行包含遥控器上每个按键的信息。0表示对应的键坏了,1表示对应的键可以使用。第5行包含2个整数,分别是X 和 Y    (0 <= X <= 99; 0 <= Y <= 99)。

输出

对每组测试数据输出一行,即将频道从编号X切换到编号Y所需要的最小按键次数。如果不可能将频道从编号X 切换到编号Y,则输出-1.

样例输入

2
0 0 1 1 
1 1 1 1
1 1 1
1 1
23 52
1 1 1 0
1 1 1 0
1 0 1
0 1
23 52

样例输出

4
-1

提示

来源

第五届河南省大学生程序设计竞赛

 

CODE:

#include<stdio.h>

#define INF 0xfffffff
#define minn(a, b)(a < b ? a : b)

int fly_to(int x, int y);
int walk_to(int x, int y);
int a[10], up, down, flash;

int main()
{
    int t, i, ans, x, y;

    scanf("%d", &t);

    while(t--)
    {
        scanf("%d%d%d%d", &a[1], &a[2], &a[3], &up);
        scanf("%d%d%d%d", &a[4], &a[5], &a[6], &down);
        scanf("%d%d%d", &a[7], &a[8], &a[9]);
        scanf("%d%d", &flash, &a[0]);
        scanf("%d%d", &x, &y);

        ans = INF;

        for(i = 0; i <= 99; i++)
        {
            ans = minn(ans, fly_to(x, i) + walk_to(i, y));
        }
        printf("%d\n", ans == INF ? -1 : ans);
    }
    return 0;
}
int fly_to(int x, int y)
{
    if(x == y)
        return 0;

    if(y / 10 == 0)
    {
        if(a[y])
            return 1;
        return INF;
    }
    else{
        if(flash && a[y/10] && a[y%10])
            return 3;
        return INF;
    }
}

int walk_to(int x, int y)
{
    int b = INF, c = INF;

    if(up)
        b = (y + 100 - x) % 100;
    if(down)
        c = (x + 100 - y) % 100;

    return minn(b, c);
}

转载于:https://www.cnblogs.com/Tinamei/p/4485166.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/431824.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php7与golang,golang 调用 php7

执行php文件func Test_exec(t *testing.T) {engine.Initialize()ctx : &engine.Context{Output: os.Stdout,}err : engine.RequestStartup(ctx)if err ! nil {fmt.Println(err)}defer engine.RequestShutdown(ctx)err ctx.Exec("/tmp/index.php")if err ! nil {…

u 20ubuntu 安装 postfix_极力推荐和田咨询问题U型钢托盘厂家

12极力推荐和田咨询问题U型钢托盘厂家泊头市毅伽属制品有限公司坐落于河北省泊头市龙华街北4公里&#xff0c;濒临京沪、石黄高速公路以及104、307国道&#xff0c;另有廊泊路贯穿南北交通十分便利。本公司设计生产各种冷弯型钢&#xff0c;产品包括C型钢、Z型钢、U型钢、M型钢…

HTML5中lineCap端点样式遇到closePath()

定义和用法 lineCap 属性设置或返回线条末端线帽的样式。 注释&#xff1a;"round" 和 "square" 会使线条略微变长。 默认值&#xff1a;buttJavaScript 语法&#xff1a;context.lineCap"butt|round|square";属性值 值描述butt默认。向线条的每…

php鼠标悬停显示图片,鼠标滑过出现预览的大图提示效果

当鼠标滑过图片时&#xff0c;图片会出现预览的大图&#xff0c;大图下面还会有介绍文字。.aa{width:88px;height :100px;}$(function () {var x 10;var y 20;$("a.tooltip").mouseover(function (e) {this.myTitle this.title;this.title "";var imgT…

405 not allowed什么意思_二驴质问散打:为什么不救天道!面临一个亿赔款?次惑小仙女宣布与可乐分手!...

次惑小仙女发作品表示&#xff1a;对不起让你们失望了&#xff0c;慢慢也学着长大了,懂得了很多,以前每天就知道天真傻笑的玩,后来懂得了努力和加油,但是很多东西并不是大家看到的那样背后的事情谁又能知道。都认为他对我很好&#xff0c;只有自己知道&#xff0c;呵呵。有些时…

阿里面试

阿里面试 转载于:https://www.cnblogs.com/chen310/p/4492243.html

matlab提示output,强制Matlab输出到命令行(Force Matlab output to command line)

强制Matlab输出到命令行(Force Matlab output to command line)我正在从Windows命令提示符运行MATLAB脚本&#xff1a;"C:\Program Files\MATLAB\R2014B\bin\matlab" -nodisplay -nosplash -nodesktop -wait -r "test.m"test.m很简单&#xff1a;function …

hdu.1254.推箱子(bfs + 优先队列)

推箱子 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 6021 Accepted Submission(s): 1718 Problem Description推箱子是一个很经典的游戏.今天我们来玩一个简单版本.在一个M*N的房间里有一个箱子和一个搬运…

ae合成设置快捷键_怎么在ae中剪切视频?怎么在ae里裁剪视频?

ae剪切裁剪视频教程&#xff1a;零基础学AE软件影视后期必修课程-AE新建合成-羽兔网​www.yutu.cn1、启动After Effects并导入视频第一个任务是打开一个新项目&#xff0c;并将视频加载到其中。首先从主菜单中选择新的构图。然后打开构图菜单&#xff0c;选择所需的分辨率等&am…

php js获取元素id,javascript通过中文id和class获取元素的方法

以前以为html元素中的id和class等只能通过字母数字或者下划线等特殊字符命名&#xff0c;如果单存使用中文浏览器不会报错&#xff0c;但是js是获取不到的&#xff0c;但是今天逛论坛的时候发现不是这样的。代码如下&#xff1a;运行结果&#xff1a;论坛来源是这个&#xff1a…

java漂亮界面编程_计算机二级之JAVA篇

JavaJava是一门面向对象编程语言&#xff0c;不仅吸收了C语言的各种优点&#xff0c;还摒弃了C里难以理解的多继承、指针等概念&#xff0c;因此Java语言具有功能强大和简单易用两个特征。深受程序员们的追捧&#xff0c;据TIBOE2020年最新统计&#xff1a;Java使用人数大涨&am…

idea 设置java栈空间,如何为Intellij编译器提供更多堆空间?

当我创建一个Intellij项目时&#xff0c;我不断收到以下内存错误。我已经在idea.vmoptions中增加了我的堆大小&#xff1a;-Xms128m-Xmx2048m-XX:MaxPermSize1024m-XX:ReservedCodeCacheSize64m-ea但我仍然得到这个错误&#xff1a;Information:The system is out of resources…

Java for LeetCode 042 Trapping Rain Water

Given n non-negative integers representing an elevation map where the width of each bar is 1, compute how much water it is able to trap after raining. For example, Given [0,1,0,2,1,0,1,3,2,1,2,1], return 6. 解题思路&#xff1a; 先找到第一块最高的木板&…

delphi random 六位_《蒙面唱将猜猜猜》第五季将播,六位唱将率先登场

原标题&#xff1a;《蒙面唱将猜猜猜》第五季将播&#xff0c;六位唱将率先登场新京报讯(记者 刘玮)《蒙面唱将猜猜猜》第五季将于11月1日21&#xff1a;10在江苏卫视首播&#xff0c;优酷视频全网独播。第五季中&#xff0c;猜评团不仅“觊觎”各路唱将的真实身份&#xff0c;…

自梦php,PHP菜狗自学之路 云之梦php php之窗 php脚本之

第一讲 开启PHP学习之路 2016/5/2 20:29PHP可以做什么&#xff1f; www网站 管理系统&#xff1b; websever wap网站第二讲 PHP的数据类型 源码调试 2016/5/2 20:30PHP和htm混编 句子以 ; 英文半角分号结束~&#xff01;&#xff01;在PHP中 以 开始 以?>结束&#xff1b;e…

鸡啄米vc++2010系列2(项目文件分析)

用应用程序向导生成框架程序后&#xff0c;我们可以在之前设置的Location下看到以解决方案名命名的文件夹&#xff0c;此文件夹中包含了几个文件和一个以工程名命名的子文件夹&#xff0c;这个子文件夹中又包含了若干个文件和一个res文件夹&#xff0c;创建工程时的选项不同&am…

python代做在哪找靠谱_比较靠谱的资产评估师考试去哪找

比较靠谱的资产评估师考试去哪找二我们一起来看看考研辅导员们哪些为优质的学习资源。考研辅导员们怎么说您好&#xff0c;我想作为有识之士&#xff0c;在现阶段大多数考研辅导员的学习水平都不行&#xff0c;甚至都不具备这些资源的才华。因此&#xff0c;我认为做好大家的准…

java中sql之count,SQL COUNT() 函数--编程学习网

COUNT() 函数返回匹配指定条件的行数。SQL COUNT(column_name) 语法COUNT(column_name) 函数返回指定列的值的数目(NULL 不计入)&#xff1a;SELECT COUNT(column_name) FROM table_name;SQL COUNT(*) 语法COUNT(*) 函数返回表中的记录数&#xff1a;SELECT COUNT(*) FROM tabl…

序列

ORACLE创建序列语句CREATE SEQUENCE 序列名 increment by (序列步长) start with &#xff08;序列起始值&#xff09; maxvalue &#xff08;序列最大值&#xff09; 删除序列DROP SEQUENCE 序列名 得到序列的下一个值序列名.nextval 创建和使用序列的例子CREATE SEQUENCE seq…

苹果笔记本双系统怎么切换_2020年你该怎么选择苹果笔记本,资深用户带你讲透MacBook Air MacBook Pro...

作为一名曾经的苹果生态开发者我2012年10月份购入自己的第一台苹果笔记本&#xff1a;MacBook Pro 13寸&#xff0c;那时候还很厚重&#xff0c;机械硬盘的配置&#xff0c;为了省钱&#xff0c;在官网翻新机渠道购买的&#xff0c;记得当初新机的原价是8000多&#xff0c;翻新…