nyoj 130 同样的雪花 【哈希】

nyoj 130 同样的雪花 【哈希】

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

同样的雪花

时间限制:
1000 ms  |  内存限制:
65535 KB
难度:
4

描写叙述
You may have heard that no two snowflakes are alike. Your task is to write a program to determine whether this is really true. Your program will read information about a collection of snowflakes, and search for a pair that may be identical. Each snowflake has six arms. For each snowflake, your program will be provided with a measurement of the length of each of the six arms. Any pair of snowflakes which have the same lengths of corresponding arms should be flagged by your program as possibly identical.

输入
The first line of the input will contain a single interger T(0<T<10),the number of the test cases.

The first line of every test case will contain a single integer n, 0 < n ≤ 100000, the number of snowflakes to follow. This will be followed by n lines, each describing a snowflake. Each snowflake will be described by a line containing six integers (each integer is at least 0 and less than 10000000), the lengths of the arms of the snow ake. The lengths of the arms will be given in order around the snowflake (either clockwise or counterclockwise), but they may begin with any of the six arms. For example, the same snowflake could be described as 1 2 3 4 5 6 or 4 3 2 1 6 5.
输出
For each test case,if all of the snowflakes are distinct, your program should print the message:

No two snowflakes are alike.

If there is a pair of possibly identical snow akes, your program should print the message:

Twin snowflakes found.
例子输入
1
2
1 2 3 4 5 6
4 3 2 1 6 5
例子输出
Twin snowflakes found.

题意:雪花有六个角,分别赋给他们长度,依照顺时针输入,问你在输入的雪花中有没有全然一样的.

分析:依照传统的做法时间是O(n^2),由于数据非常大所以说会超时,要换一种方法,要用到散列表(大神们讲的非常具体,我就现丑了)。

这道题的比較也蛮奇特的。

代码1(链表形式):

#include <cstdio>
#include <cstring>
#define M 20005
using namespace std;
struct node
{
	int a[6];
	struct node *next;
	/* data */
};
node *s[M];

int match(int *temp, int sum){
	int i, j;
	node *p; p = s[sum]->next;
	while(p){
		for(i = 0; i < 6; ++ i){
			for(j = 0; j < 6; ++ j){
				if(temp[j] != p->a[(i+j)%6]) break;
			}
			if(j == 6) return true;
			for(j = 0; j < 6; ++ j){
				if(temp[j] != p->a[(i+6-j)%6]) break;
			}
			if(j == 6) return true;
		}
		p = p->next;
	}
	p = new node;
	for(i = 0; i < 6; ++ i) p->a[i] = temp[i];
	p->next = s[sum]->next;
	s[sum]->next = p;
	return false;
}
int main(){
	int t, n, i, j, temp[6];
	scanf("%d", &t);
	while(t --){
		int sum,flag = 0;
		scanf("%d", &n);
		for(i = 0; i < M; ++ i){
			s[i] = new node; s[i]->next = NULL;
		}
		while(n --){
			sum = 0;
			for(i = 0; i < 6; ++i){
				scanf("%d", &temp[i]);
				sum += temp[i];
			}
			sum %= M;
			if(!flag){
				if(match(temp, sum)) flag = 1;
			}
		}
		if(flag) puts("Twin snowflakes found.");
		else puts("No two snowflakes are alike.");
	}
	return 0;
}        

代码2(三维数组):

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define M 20000
int s[M][100][6];
int len[M];

int match(int *a, int *b){
	int i, j, k;
	for(i = 0; i < 6; i ++){
		for(j = 0; j < 6; j ++){
			if(a[j] != b[(i+j)%6]) break;
		}
		if(j == 6) return true;
		for(j = 0; j < 6; j ++){
			if(a[j] != b[(i+6-j)%6]) break;
		}
		if(j == 6) return true;
	}
	return false;
}
int main(){
	int t, n, sum, temp[6];
	scanf("%d", &t);
	while(t --){
		int i, j, k, flag = 0;
		scanf("%d", &n);
		memset(len, 0, sizeof(int)*(M+1));
		while(n --){
			sum = 0;
			for(i = 0; i < 6; i ++){
				scanf("%d",&temp[i]);
				sum += temp[i];
			}
			sum %= M;
			for (i = 0; i < 6; ++i){
				s[sum][len[sum]][i] = temp[i];
			}
			++len[sum];
		}
		for(i = 0; i < M; i ++){
			if(len[i] >1)
			for(j = 0; j < len[i]-1; j ++){
				for(k = j+1; k < len[i]; k ++){
					if(match(s[i][j], s[i][k])){
						flag = 1; 
						 break;
					}
				}
				if(flag) break;
			}
			if(flag) break;
		}
		if(flag) puts("Twin snowflakes found.");
		else puts("No two snowflakes are alike.");
	}
	return 0;
}
        

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118043.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 图神经网络(GNN)的简介「建议收藏」

    近年来,图神经网络(GNN)在社交网络、知识图、推荐系统甚至生命科学等各个领域得到了越来越广泛的应用。GNN在对图节点之间依赖关系进行建模的强大功能,使得与图分析相关的研究领域取得了突破。本文介绍了图神经网络的基本原理,以及两种高级的算法,DeepWalk和GraphSage。图(Graph)在讨论GNN之前,我们先来了解一下什么是图。在计算机科学中,图是由顶点和边两部分组成的一种数据结构…

    2022年4月18日
    223
  • OPKG 软件包管理

    OPKG 软件包管理Opkg是一个轻量快速的套件管理系统,目前已成为Opensource界嵌入式系统标准。常用于路由、交换机等嵌入式设备中,用来管理软件包的安装升级与下载。中文名opkg属    性套件管理系统更    新可以获取的软件包列表常用于路由、交换机等嵌入式设备常用命令opkgupdate更新可以获取的软件包列表

    2022年6月14日
    26
  • 微信小程序 宠物论坛1[通俗易懂]

    微信小程序 宠物论坛1[通俗易懂]微信小程序宠物论坛(1)一个简单的论坛包括以下几个方面:登录模块发帖模块首页模块帖子详情模块搜索模块个人主页模块下面将从这6个方面介绍如何用微信小程序开发一个简单的论坛。1、登录模块先看界面图打开小程序首先看到这个界面,之后我们点击头像便完成授权登录。JS部分//index.js//获取应用实例constapp=getApp()constdb=wx.cloud.database()Page({data:{motto:’欢迎来到宠物论坛

    2022年10月7日
    6
  • springboot启动流程源码分析(二)

    springboot启动流程源码分析(二)

    2021年8月3日
    58
  • VC++消息钩子编程「建议收藏」

    VC++消息钩子编程「建议收藏」一、消息钩子的概念1、基本概念Windows应用程序是基于消息驱动的,任何线程只要注册窗口类都会有一个消息队列用于接收用户输入的消息和系统消息。为了拦截消息,Windows提出了钩子的概念。钩子(H

    2022年7月1日
    47
  • git设置ssh key(git ssh配置)

    gitclone支持https和git(即ssh)两种方式下载源码:当使用git方式下载时,如果没有配置过sshkey,则会有如下错误提示:下面就介绍一下如何配置git的sshkey,以便我们可以用git方式下载源码。首先用如下命令(如未特别说明,所有命令均默认在GitBash工具下执行)检查一下用户名和邮箱是否配置(github支持我们用用户名或邮箱登录):git

    2022年4月12日
    53

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号