鱼C论坛

 找回密码
 立即注册
查看: 2890|回复: 3

[已解决]字符串

[复制链接]
发表于 2023-4-27 17:21:34 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
如果从一个字符串中删除一个字符可以生成另一个字符串,如 “abc”和“abxc”。

输入

输入参数为两个非空的字符串str1和str2。


输出

仅当从str1中删除一个字符可以得到str2,或者从str2中删除一个字符可以得到str1时,返回True;否则输出False。


输入样例1
abcd abcde
输出样例1
True

输入样例2
abcd abcd
输出样例2
False
最佳答案
2023-4-29 11:34:13
  1. def is_one_char_diff(str1, str2):
  2.     if len(str1) == len(str2):
  3.         count_diff = 0
  4.         for i in range(len(str1)):
  5.             if str1[i] != str2[i]:
  6.                 count_diff += 1
  7.             if count_diff > 1:
  8.                 return False
  9.         return count_diff == 1
  10.     elif abs(len(str1) - len(str2)) == 1:
  11.         if len(str1) > len(str2):
  12.             str1, str2 = str2, str1
  13.         i = j = 0
  14.         while i < len(str1) and j < len(str2):
  15.             if str1[i] != str2[j]:
  16.                 j += 1
  17.                 if j - i > 1:
  18.                     return False
  19.             else:
  20.                 i += 1
  21.                 j += 1
  22.         return True
  23.     else:
  24.         return False
复制代码

这个函数可以判断两个字符串是否只有一个字符的差别。首先判断两个字符串长度是否相等,如果相等,则统计不同的字符数,如果不同的字符数为1,则返回True;否则返回False。如果两个字符串长度相差1,则将较短的字符串作为str1,从左到右遍历两个字符串,遇到不同的字符则将较长字符串的指针j后移一位,如果j和i之间的距离大于1,则返回False;否则继续遍历,直到遍历完较短的字符串,如果都没有返回False,则返回True。如果两个字符串长度差别大于1,则直接返回False。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-4-27 17:28:18 | 显示全部楼层
您可以使用以下Python函数来解决这个编程问题:

  1. def can_form_by_deleting_one_char(str1, str2):
  2.     if abs(len(str1) - len(str2)) != 1:
  3.         return False

  4.     shorter, longer = (str1, str2) if len(str1) < len(str2) else (str2, str1)

  5.     i = j = 0
  6.     found_difference = False
  7.     while i < len(shorter) and j < len(longer):
  8.         if shorter[i] != longer[j]:
  9.             if found_difference:
  10.                 return False
  11.             found_difference = True
  12.             j += 1
  13.         else:
  14.             i += 1
  15.             j += 1

  16.     return True

  17. # 输入样例1
  18. print(can_form_by_deleting_one_char("abcd", "abcde"))  # 输出样例1: True
  19. # 输入样例2
  20. print(can_form_by_deleting_one_char("abcd", "abcd"))  # 输出样例2: False
复制代码


这个函数首先检查两个字符串的长度差是否为1。如果不是,直接返回False。然后,确定较短和较长的字符串。接下来,在较短和较长的字符串之间进行逐字符比较。当找到第一个不匹配的字符时,仅跳过较长字符串中的该字符。如果找到第二个不匹配的字符,则返回False。如果在比较过程中没有找到第二个不匹配的字符,那么返回True。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2023-4-27 19:41:02 | 显示全部楼层
  1. def can_transform(str1, str2):
  2.     for i in range(len(str1)):
  3.         if str1[:i] + str1[i+1:] == str2:
  4.             return True
  5.     for i in range(len(str2)):
  6.         if str2[:i] + str2[i+1:] == str1:
  7.             return True
  8.     return False

  9. a = input().split()
  10. print(can_transform(a[0], a[1]))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2023-4-29 11:34:13 | 显示全部楼层    本楼为最佳答案   
  1. def is_one_char_diff(str1, str2):
  2.     if len(str1) == len(str2):
  3.         count_diff = 0
  4.         for i in range(len(str1)):
  5.             if str1[i] != str2[i]:
  6.                 count_diff += 1
  7.             if count_diff > 1:
  8.                 return False
  9.         return count_diff == 1
  10.     elif abs(len(str1) - len(str2)) == 1:
  11.         if len(str1) > len(str2):
  12.             str1, str2 = str2, str1
  13.         i = j = 0
  14.         while i < len(str1) and j < len(str2):
  15.             if str1[i] != str2[j]:
  16.                 j += 1
  17.                 if j - i > 1:
  18.                     return False
  19.             else:
  20.                 i += 1
  21.                 j += 1
  22.         return True
  23.     else:
  24.         return False
复制代码

这个函数可以判断两个字符串是否只有一个字符的差别。首先判断两个字符串长度是否相等,如果相等,则统计不同的字符数,如果不同的字符数为1,则返回True;否则返回False。如果两个字符串长度相差1,则将较短的字符串作为str1,从左到右遍历两个字符串,遇到不同的字符则将较长字符串的指针j后移一位,如果j和i之间的距离大于1,则返回False;否则继续遍历,直到遍历完较短的字符串,如果都没有返回False,则返回True。如果两个字符串长度差别大于1,则直接返回False。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-24 23:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表