HR_Sherlock and Anagrams_TIMEOUT[UNDONE]
2019年1月10日15:39:23 去掉了所有不必要的循环区间 还是超时 本地运行大概3s
#!/bin/python3 import math
import os
import random
import re
import sys # Complete the sherlockAndAnagrams function below.
def compareSubString(string1,string2):
num_string1 = [0]*26
num_string2 = [0]*26
for index in range (len(string1)):
temp = ord(string1[index]) - ord('a')
num_string1[temp] +=1
temp = ord(string2[index]) - ord('a')
num_string2[temp] +=1 if num_string1 == num_string2:
return True
else:
return False def sherlockAndAnagrams(s): #s <= 100
n = len(s)
count = 0
for index in range(n-1): #last one have no mean
for length in range(1, n - index): #only length between [1,n-1] passible have Anagrams
tempstring1 = s[index : index + length]
if (index + 1 <= n - length ):
for index2 in range(index + 1, n - length +1):
tempstring2 = s[index2: index2 + length]
if compareSubString(tempstring1 , tempstring2):
count +=1
return count if __name__ == '__main__':
# fptr = open(os.environ['OUTPUT_PATH'], 'w') q = 1 for q_itr in range(q):
s = 'zjekimenscyiamnwlpxytkndjsygifmqlqibxxqlauxamfviftquntvkwppxrzuncyenacfivtigvfsadtlytzymuwvpntngkyhw' result = sherlockAndAnagrams(s) print(result)
------
注意 anagrammatic 是拼字游戏的意思,任意调换顺序可以组成对方都成立,不是简单的回文数字。
------
1.第一种解法想省些时间 结果都比测试集少了20多个 应该是有些规则题目没有描述清楚。
5
ifailuhkqqhucpoltgtyovarjsnrbfpvmupwjjjfiwwhrlkpekxxnebfrwibylcvkfealgonjkzwlyfhhkefuvgndgdnbelgruel
gffryqktmwocejbxfidpjfgrrkpowoxwggxaknmltjcpazgtnakcfcogzatyskqjyorcftwxjrtgayvllutrjxpbzggjxbmxpnde
mqmtjwxaaaxklheghvqcyhaaegtlyntxmoluqlzvuzgkwhkkfpwarkckansgabfclzgnumdrojexnrdunivxqjzfbzsodycnsnmw
ofeqjnqnxwidhbuxxhfwargwkikjqwyghpsygjxyrarcoacwnhxyqlrviikfuiuotifznqmzpjrxycnqktkryutpqvbgbgthfges
zjekimenscyiamnwlpxytkndjsygifmqlqibxxqlauxamfviftquntvkwppxrzuncyenacfivtigvfsadtlytzymuwvpntngkyhw
399
471
370
403
428
#!/bin/python3 import math
import os
import random
import re
import sys # Complete the sherlockAndAnagrams function below.
def sherlockAndAnagrams(s):
n = len(s)
count = 0
# len = 1 && multi in string
for i in range(n):
for j in range(n):
if j > i:
if s[j] == s[i]:
count += 1
if j - i > 1:
count += 1 # repeat substring && huiwen substring
for start in range(n):
for end in range(n):
if end - start > 1: # substring len > 1
substring_num = 0
reverse_substring_num = 0
str1 = s[start:end]
str2 = s[end:]
str3 = str1[::-1]
substring_num = str2.count(str1)
reverse_substring_num = str2.count(str3)
count += substring_num
if str1 != str3: # avoid kkk
count += reverse_substring_num return count if __name__ == '__main__': s = 'zjekimenscyiamnwlpxytkndjsygifmqlqibxxqlauxamfviftquntvkwppxrzuncyenacfivtigvfsadtlytzymuwvpntngkyhw' result = sherlockAndAnagrams(s)
# fptr = open(os.environ['OUTPUT_PATH'], 'w')
#
# q = int(input())
#
# for q_itr in range(q):
# s = 'abba'
#
# result = sherlockAndAnagrams(s)
#
# fptr.write(str(result) + '\n')
#
# fptr.close()
2.看s 最大也就100 直接列出所有子串排序求和就行 但是发现会超时,本地运行需要十几秒。。。:
#!/bin/python3 import math
import os
import random
import re
import sys # Complete the sherlockAndAnagrams function below.
def sherlockAndAnagrams(s):
n = len(s)
count = 0
#find all substring
arr = []
for i in range(n):
for j in range(n+1):
if j > i:
arr.append(s[i:j])
# count
count = 0
for i in range(len(arr)):
for j in range(len(arr)):
if j>i and len(arr[i] )== len(arr[j]):
str1 = sorted(arr[i])
str2 = sorted(arr[j])
if str1 == str2 :
count += 1
return count if __name__ == '__main__': s = 'mqmtjwxaaaxklheghvqcyhaaegtlyntxmoluqlzvuzgkwhkkfpwarkckansgabfclzgnumdrojexnrdunivxqjzfbzsodycnsnmw' result = sherlockAndAnagrams(s)
# fptr = open(os.environ['OUTPUT_PATH'], 'w')
#
# q = int(input())
#
# for q_itr in range(q):
# s = 'abba'
#
# result = sherlockAndAnagrams(s)
#
# fptr.write(str(result) + '\n')
#
# fptr.close()
3.优化了下 改成字符串 还是超时:
#!/bin/python3 import math
import os
import random
import re
import sys # Complete the sherlockAndAnagrams function below.
def sherlockAndAnagrams(s):
n = len(s)
count = 0
#find all substring
arr = []
for i in range(n):
for j in range(n+1):
if j > i:
arr.append(s[i:j])
# count
count = 0
# for i in range(len(arr)):
# for j in range(len(arr)):
# if j>i and len(arr[i] )== len(arr[j]):
# str1 = sorted(arr[i])
# str2 = sorted(arr[j])
# if str1 == str2 :
# count += 1 for i in range(len(arr)):
temp = "".join(sorted(arr[i]))
arr[i] = temp for i in range(len(arr)):
for j in range(i,len(arr)):
if j>i and len(arr[i] )== len(arr[j]) and arr[i] == arr[j]:
count += 1
return count if __name__ == '__main__': s = 'ifailuhkqqhucpoltgtyovarjsnrbfpvmupwjjjfiwwhrlkpekxxnebfrwibylcvkfealgonjkzwlyfhhkefuvgndgdnbelgruel' result = sherlockAndAnagrams(s) print(result)
# fptr = open(os.environ['OUTPUT_PATH'], 'w')
#
# q = int(input())
#
# for q_itr in range(q):
# s = 'abba'
#
# result = sherlockAndAnagrams(s)
#
# fptr.write(str(result) + '\n')
#
# fptr.close()
HR_Sherlock and Anagrams_TIMEOUT[UNDONE]的更多相关文章
- IIS FTP Server Anonymous Writeable Reinforcement, WEBDAV Anonymous Writeable Reinforcement(undone)
目录 . 引言 . IIS 6.0 FTP匿名登录.匿名可写加固 . IIS 7.0 FTP匿名登录.匿名可写加固 . IIS >= 7.5 FTP匿名登录.匿名可写加固 . IIS 6.0 A ...
- C++ Standard Template Library STL(undone)
目录 . C++标准模版库(Standard Template Library STL) . C++ STL容器 . C++ STL 顺序性容器 . C++ STL 关联式容器 . C++ STL 容 ...
- Codeforces 1154 - A/B/C/D/E/F/G - (Undone)
链接:https://codeforces.com/contest/1154 A - Restoring Three Numbers - [水] #include<bits/stdc++.h&g ...
- Gym 101606 - A/B/C/D/E/F/G/H/I/J/K/L - (Undone)
链接:https://codeforces.com/gym/101606 A - Alien Sunset 暴力枚举小时即可. #include<bits/stdc++.h> using ...
- Codeforces 677 - A/B/C/D/E - (Undone)
链接: A - Vanya and Fence - [水] AC代码: #include<bits/stdc++.h> using namespace std; ; int n,h; in ...
- Codeforces 1114 - A/B/C/D/E/F - (Undone)
链接:http://codeforces.com/contest/1114 A - Got Any Grapes? 题意:甲乙丙三个人吃葡萄,总共有三种葡萄:绿葡萄.紫葡萄和黑葡萄,甲乙丙三个人至少要 ...
- 2016ACM/ICPC亚洲区沈阳站 - A/B/C/E/G/H/I - (Undone)
链接:传送门 A - Thickest Burger - [签到水题] ACM ICPC is launching a thick burger. The thickness (or the heig ...
- Codeforces 1043 - A/B/C/D/E/F - (Undone)
链接:http://codeforces.com/contest/1043 A - Elections - [水水水水题] 题意: 我和另一个人竞争选举,共有 $n$ 个人投票,每个人手上有 $k$ ...
- VS中特殊的注释——TODO/UNDONE/HACK的使用
在代码的后面添加形如下面注释: //TODO: (未实现)…… //UNDONE:(没有做完)…… //HACK:(修改)…… 等到再次打开VS的时候,找到 :视图>任务列表 即可显示所有带有T ...
随机推荐
- JavaScript对象访问器属性
对象访问器就是setter和getter,他们的作用就是 提供另外一种方法来获取或者设置对象的属性值, 并且在获取和设置的时候,可以用一定的其他操作. 看下面代码: <script> va ...
- 3proxy使用方法
转自:DRL@fireinice写的教程 ******************************************************************************* ...
- VMware虚拟机与Windows文件共享
开发中,我们经常的需求是这样的:我想再Windows中进行快捷开发,但是想在linux中运行,那么需要将文件方便在linux中管理,基本可以分成两种方式: 1. 使用网络工具:vmware_tool工 ...
- webdriver原理、协议
1.webdriver client的原理是什么? 当测试脚本启动firefox的时候,selenium-webdriver 会首先在新线程中启动firefox浏览器.如果测试脚本指定了firefox ...
- windows浏览器访问虚拟机开的rabbitmq服务,无法访问
根据这个博主的建议 https://blog.csdn.net/csdnliuxin123524/article/details/78207427 换了一个浏览器上火狐浏览器输入“localhost: ...
- Partition算法以及其应用详解上(Golang实现)
最近像在看闲书一样在看一本<啊哈!算法> 当时在amazon上面闲逛挑书,看到巨多人推荐这本算法书,说深入浅出简单易懂便买来阅读.实际上作者描述算法的能力的确令人佩服.就当复习常用算法吧. ...
- 【Spring】——声明式事务配置详解
项目中用到了spring的事务: @Transactional(rollbackFor = Exception.class, transactionManager = "zebraTrans ...
- 莫烦theano学习自修第七天【回归结果可视化】
1.代码实现 from __future__ import print_function import theano import theano.tensor as T import numpy as ...
- List接口方法
package cn.zhou.com; /* * List?-------是啥? Collection 的一个子接口! * * 集合?容器? * * 区分容器,每个容器的数据结构不一样! * 集合, ...
- springboot+jpa+mysql+swagger整合
Springboot+jpa+MySQL+swagger整合 创建一个springboot web项目 <dependencies> <dependency> < ...