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]的更多相关文章

  1. 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 ...

  2. C++ Standard Template Library STL(undone)

    目录 . C++标准模版库(Standard Template Library STL) . C++ STL容器 . C++ STL 顺序性容器 . C++ STL 关联式容器 . C++ STL 容 ...

  3. Codeforces 1154 - A/B/C/D/E/F/G - (Undone)

    链接:https://codeforces.com/contest/1154 A - Restoring Three Numbers - [水] #include<bits/stdc++.h&g ...

  4. 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 ...

  5. Codeforces 677 - A/B/C/D/E - (Undone)

    链接: A - Vanya and Fence - [水] AC代码: #include<bits/stdc++.h> using namespace std; ; int n,h; in ...

  6. Codeforces 1114 - A/B/C/D/E/F - (Undone)

    链接:http://codeforces.com/contest/1114 A - Got Any Grapes? 题意:甲乙丙三个人吃葡萄,总共有三种葡萄:绿葡萄.紫葡萄和黑葡萄,甲乙丙三个人至少要 ...

  7. 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 ...

  8. Codeforces 1043 - A/B/C/D/E/F - (Undone)

    链接:http://codeforces.com/contest/1043 A - Elections - [水水水水题] 题意: 我和另一个人竞争选举,共有 $n$ 个人投票,每个人手上有 $k$ ...

  9. VS中特殊的注释——TODO/UNDONE/HACK的使用

    在代码的后面添加形如下面注释: //TODO: (未实现)…… //UNDONE:(没有做完)…… //HACK:(修改)…… 等到再次打开VS的时候,找到 :视图>任务列表 即可显示所有带有T ...

随机推荐

  1. mysql常用命令行操作(二):表和库的操作、引擎、聚合函数

    一.查看.创建.删除数据库 create database library default character set utf8 collate utf8_general_ci; # 创建数据库并设置 ...

  2. QueryRunner 错误

    QueryRunner qr=new QueryRunner(JDBCUtils.getDataSource()); 写成了 QueryRunner qr = new QueryRunner(); 导 ...

  3. jQuery ajax解析xml文件demo

    解析xml文件,然后将城市列表还原到下拉列表框中:当选择下拉列表框时,在对应的文本框中显示该城市信息. 前端代码: <!doctype html> <html> <hea ...

  4. PreparedStatement和Statement

    1 . PreparedStatement 接口继承 Statement , PreparedStatement 实例包含已编译的 SQL 语句,所以其执行速度要快于 Statement 对象. 2  ...

  5. java学习之—使用栈实现字符串数字四则运算

    /** * 使用栈存储后缀表达式 * Create by Administrator * 2018/6/13 0013 * 下午 2:25 **/ public class StackX { priv ...

  6. Postman & API

    Postman & API https://www.getpostman.com/ https://www.getpostman.com/downloads/ Postman Canary h ...

  7. shiro使用ajax登陆实现,success但页面无法跳转的问题

    首先:简述一下登陆的后台流程 页面提交——>对应controller中的方法——>对应Realm认证——>controller返回 json 这样,无论成功与否,都有返回值,可以用 ...

  8. 错误模块名称: KERNELBASE.dll

    部署win服务时,经常会出现类似下面的错误,错误模块名称: KERNELBASE.dll. 日志名称:          Application 来源:            Application ...

  9. 替换JDK 对eclipse的影响?

    问题  替换原有的JDK 对 eclipse有影响么? 之前用的eclipse是32位的,我的电脑是64位的,装的JDK是也是32位的,所以不影响使用! 但是,前两天装了一个ideal,新配置了一个9 ...

  10. Nintex Workflow Get Attachment link

    不多解释,直接上图,操作简单