打印两个字符串中按字母顺序排列的公共字符的 Python 代码


给定两个由用户输入的字符串,我们的任务是以字母顺序打印所有公共字符。

示例

Input:
string1: python
string2: program
Output: op

说明

两个字符串之间的公共字母依次是 o(1 次)、p(1 次)

算法

Step 1: first we take two input string.
Step 2: next we will do to convert these two strings into counter dictionary.
Step 3: Now find common elements between two strings using intersection ( ) property.
Step 4: Resultant will also be a counter dictionary having common elements as keys and their common frequencies as value.
Step 5: Use elements () method of the counter dictionary to expand the list of keys by their frequency number of times.
Step 6: sort list in ascending order to print a resultant string in alphabetical order.
Step 7: join characters without space to produce resultant string.

示例代码

from collections import Counter
def common(str1,str2):
   d1 = Counter(str1)
   d2 = Counter(str2)
   cdict = d1 & d2
   if len(cdict) == 0:
      print -1
   return
   cchars = list(cdict.elements())
   cchars = sorted(cchars)
   print ("Common characters are ::>",''.join(cchars) )
      # Driver program
   if __name__ == "__main__":
      s1 = input("Enter first string")
      s2 = input("Enter second string")
common(s1, s2)

输出

Enter first string python
Enter second string program
Common characters are ::> op

更新于: 23-Jun-2020

905 查看

启动你的 职业生涯

完成课程取得认证

立即开始
广告