Picking up Jewels

There is a maze that has one entrance and one exit. 

Jewels are placed in passages of the maze. 

You want to pick up the jewels after getting into the maze through the entrance and before getting out of it through the exit. 

You want to get as many jewels as possible, but you don’t want to take the same passage you used once.

When locations of a maze and jewels are given, 

find out the greatest number of jewels you can get without taking the same passage twice, and the path taken in this case.

Time limit : 1 sec (Java : 2 sec) (If your program exceeds this time limit, the answers that have been already printed are ignored and the score becomes 0. So, it may be better to print a wrong answer when a specific test case
might cause your program to exceed the time limit. One guide for the time limit excess would be the size of the input.)

[Input]

There can be more than one test case in the input file. The first line has T, the number of test cases. 

Then the totally T test cases are provided in the following lines (T ≤ 10 )

In each test case, 

In the first line, the size of the maze N (1 ≤ N ≤ 10) is given. The maze is N×N square-shaped. 

From the second line through N lines, information of the maze is given. 

“0” means a passage, “1” means a wall, and “2” means a location of a jewel. 

The entrance is located on the upper-most left passage and the exit is located on the lower-most right passage. 

There is no case where the path from the entrance to the exit doesn’t exist.

[Output]

For each test case, you should print "Case #T" in the first line where T means the case number.

For each test case, from the first line through N lines, mark the path with 3 and output it.

In N+1 line, output the greatest number of jewels that can be picked up. 



[I/O Example]

Input





0 0 0 2 0

2 1 0 1 2

0 0 2 2 0

0 1 0 1 2

2 0 0 0 0



0 1 2 1 0 0

0 1 0 0 0 1

0 1 2 1 2 1

0 2 0 1 0 2

0 1 0 1 0 1

2 0 2 1 0 0

Output

Case #1

3 0 3 3 3 

3 1 3 1 3 

3 0 3 2 3 

3 1 3 1 3 

3 3 3 0 3

Case #2

3 1 2 1 0 0 

3 1 3 3 3 1 

3 1 3 1 3 1 

3 2 3 1 3 2 

3 1 3 1 3 1 

3 3 3 1 3 3

/*

You should use the statndard input/output

in order to receive a score properly.

Do not use file input and output

Please be very careful.

*/

#include <stdio.h>

#define MAX_N  11

#define true   1

#define false  0

int Array[MAX_N][MAX_N];

int Path[MAX_N][MAX_N];//保存走过的路径

int Visited[MAX_N][MAX_N];//标记走过的路径

int Answer[MAX_N][MAX_N];

int Max_Jewes;

int N;

//int total ;

//int Answer = 0 ;

void SavePath()

{

int i,j;

for(i=0;i<N;i++)

{

for(j=0;j<N;j++)

{

Answer[i][j] = Path[i][j];

}

}

}

int Visit(int i, int j, int total)

{

int ret = 0;

Path[i][j] = 3 ;

Visited[i][j] = true ;

{

total++;

}

if((i == N-1)&&(j == N-1))//假设到达终点,则推断本次遍历的结果和之前全部次数中最大的结果最比較。假设大于之前的结果。则保存这个最大值和本次路径

{

if(total > Max_Jewes)

{

Max_Jewes = total ;

SavePath();

}

Visited[i][j] = false ;//将终点标记成未扫描过,使下一次遍历还能够扫描到该点

return 1;

}

if((j+1) <= (N-1))//down

{

{

。继续遍历

Visit(i, j+1, total+1);

else

Visit(i, j+1, total);//假设没有宝藏,则总数不变,继续遍历

Path[i][j+1] = Array[i][j+1] ;//死角,回退之后恢复path的值

}

}

if((j-1) >= 0)//up

{

if((!Visited[i][j-1])&&(Array[i][j-1] != 1))

{

if(Array[i][j-1] == 2)

Visit(i , j-1, total+1);

else

Visit(i , j-1, total);

Path[i][j-1] = Array[i][j-1] ;

}

}

if((i+1) <= (N-1))//right

{

if((!Visited[i+1][j])&&(Array[i+1][j] != 1))

{

if(Array[i+1][j] == 2)

Visit(i+1 , j, total+1);

else

Visit(i+1 , j, total);

Path[i+1][j] = Array[i+1][j] ;

}

}

if((i-1) >= 0)//left

{

if((!Visited[i-1][j])&&(Array[i-1][j] != 1))

{

if(Array[i-1][j] == 2)

Visit(i-1 , j, total+1);

else

Visit(i-1 , j, total);

Path[i-1][j] = Array[i-1][j];

}

}

Visited[i][j] = false ;

return -1;

}

int main(void)

{

int T, test_case;

/*

The freopen function below opens input.txt file in read only mode, and afterward,

the program will read from input.txt file instead of standard(keyboard) input.

To test your program, you may save input data in input.txt file,

and use freopen function to read from the file when using scanf function.

You may remove the comment symbols(//) in the below statement and use it.

But before submission, you must remove the freopen function or rewrite comment symbols(//).

*/

freopen("sample_input.txt", "r", stdin);

/*

If you remove the statement below, your program's output may not be rocorded

when your program is terminated after the time limit.

For safety, please use setbuf(stdout, NULL); statement.

*/

setbuf(stdout, NULL);

scanf("%d", &T);

for(test_case = 0; test_case < T; test_case++)

{

int i ,j ;

//total = 0 ;

Max_Jewes = -1 ;

scanf("%d",&N);

for(i=0;i<N;i++)

{

for(j=0;j<N;j++)

{

scanf("%d",&Array[i][j]);

Path[i][j] = Array[i][j];

}

}

for(i=0;i<N;i++)

{

for(j=0;j<N;j++)

{

Visited[i][j] = false ;////初始化遍历标志

}

}

Visit(0 , 0, 0);

printf("Case #%d\n", test_case+1);

//printf("%d\n", Answer);

for(i=0;i<N;i++)

{

for(j=0;j<N;j++)

{

printf("%d ",Answer[i][j]);

}

printf("\n");

}

printf("%d\n", Max_Jewes);

/////////////////////////////////////////////////////////////////////////////////////////////

/*

Implement your algorithm here.

The answer to the case will be stored in variable Answer.

*/

/////////////////////////////////////////////////////////////////////////////////////////////

//Answer = 0;

// Print the answer to standard output(screen).

//printf("Case #%d\n", test_case+1);

//printf("%d\n", Answer);

}

return 0;//Your program should return 0 on normal termination.

}

Picking up Jewels的更多相关文章

  1. hdu.1044.Collect More Jewels(bfs + 状态压缩)

    Collect More Jewels Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  2. Google Code Jam 2010 Round 1B Problem B. Picking Up Chicks

    https://code.google.com/codejam/contest/635101/dashboard#s=p1   Problem A flock of chickens are runn ...

  3. HDU 1044 Collect More Jewels(BFS+DFS)

    Collect More Jewels Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  4. 深入理解OpenGL拾取模式(OpenGL Picking)

    深入理解OpenGL拾取模式(OpenGL Picking) 本文转自:http://blog.csdn.net/zhangci226/article/details/4749526 在用OpenGL ...

  5. hdu 1044 Collect More Jewels(bfs+状态压缩)

    Collect More Jewels Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  6. codechef Jewels and Stones 题解

    Soma is a fashionable girl. She absolutely loves shiny stones that she can put on as jewellery acces ...

  7. The Material Sourcing Process Failed To Create Picking Suggestions in INVTOTRX (文档 ID 2003806.1)

    In this Document Symptoms Cause Solution References Applies to: Oracle Inventory Management - Versio ...

  8. 实现一个简单的Unity3D三皮卡——3D Picking (1)

    3D Picking 其原理是从摄像机位置到空间发射的射线.基于光线碰到物体回暖. 这里我们使用了触摸屏拿起触摸,鼠标选择相同的原理,仅仅是可选API不同. 从unity3D官网Manual里找到下面 ...

  9. LeetCode --> 771. Jewels and Stones

    Jewels and Stones You're given strings J representing the types of stones that are jewels, and S rep ...

随机推荐

  1. [HTML5] Handle Offscreen Accessibility

    Sometime when some component is offscreen, but still get focus when we tab though the page. This can ...

  2. [HTML5] Accessibility Implementation for complex component

    When you developing a complex component by your own, one thing you cannot ignore is Accessibility. C ...

  3. 程序猿的量化交易之路(18)--Cointrader之Event实体(6)

    转载需注明: 事件,是Esper的重要概念. 这里我们定义个事件类.它是Temporal实体的派生类. 不过对Temporal简单的包装.其代码例如以下: package org.cryptocoin ...

  4. 使用android.graphics.Path类自绘制PopupWindow背景

    PopupWindow简单介绍 PopupWindow是悬浮在当前activity上的一个容器,用它能够展示随意的内容. PopupWindow跟位置有关的API有以下几个: showAsDropDo ...

  5. linux下的静态库创建与查看,及如何查看某个可执行依赖于哪些动态库

    linux下的静态库创建与查看,及如何查看某个可执行依赖于哪些动态库   创建静态库:ar -rcs test.a *.o查看静态库:ar -tv test.a解压静态库:ar -x test.a 查 ...

  6. mysql事务的开启

    mysql事务的开启 对于一个MYSQL数据库(InnoDB),事务的开启与提交模式无非下面这两种情况: 1>若参数autocommit=0,事务则在用户本次对数据进行操作时自动开启,在用户执行 ...

  7. SAN和NAS

    SAN针对海量.面向数据块的数据传输,而NAS则提供文件级的数据访问功能. SAN和NAS都基于开放的.业界标准的网络协议:用于SAN的光纤通道协议和用于NAS的网络协议(如TCP/IP). SAN的 ...

  8. Solidworks.2016.SP5下载安装破解图文教程

    安装此软件一定要断网安装!!!下载完成后解压文件,打开破解文件夹,双击文件夹中的SolidWorksSerialNumbers2016.reg进行注册表注册,如下图.   解压软件安装包(或者将软件安 ...

  9. MeayunDB-高性能分布式内存数据库

    MeayunDB(www.meayun.com)是一款分布式的NoSQL列式内存数据库,由C#编写,主要为高性能,高并发,高可伸缩及大数据系统提供技术解决方案.基于MeayunDB,可以简单,快速的构 ...

  10. requests模块的高级用法

    SSL Cert Verification #证书验证(大部分网站都是https) import requests respone=requests.get('https://www.12306.cn ...