不相同的字符串 acm模式刷题

题目描述

给定一个只包含小写字母的字符串,每次操作可以将两个相同的字母删除,然后在字符串的末尾新增任意一个小写字母。请问最少需要多少次操作,才能使字符串中所有的字母都不相同。
输入描述

第一行是一个整数 N,表示后续会有 N 个字符串,每个字符串占一行。
输出描述

对于输入的每一个字符串,你需要输出该字符串所需的最少操作次数,每个输出占一行。
输入示例

复制代码
1
abab

输出示例

复制代码
2

解题思路: 1.贪心算法 2.通过构造大小为26的列表,记录字符串中不同字符出现的次数,循环字典,更新出现次数最多的字符的数量和次数出现最少的字符的数量,直至列表中不存在数量大于1,则退出循环。

python 复制代码
def CountString(strings):
    letter_count = [0]*26
    for j in strings:
       letter_count[ord(j) - 97] += 1
    count = 0
    while(max(letter_count) > 1):
        for x in range(26):
            if letter_count[x] > 1:
                letter_count[x] -= 2
                count += 1
                break
        min_letter = min(letter_count)
        for y in range(26):
            if min_letter == letter_count[y]:
                letter_count[y] += 1
                break
    return count
if __name__ == "__main__":
	n = input().split()
	n = int(n[0])
	for i in range(n):
	    string = input()
	    num = CountString(string)
	    print(num)
相关推荐
biter down12 分钟前
C++ 解决海量数据 TopK 问题:小根堆高效解法
c++·算法
用户66006766853915 分钟前
斐波那契数列:从递归到缓存优化的极致拆解
前端·javascript·算法
初夏睡觉21 分钟前
P1055 [NOIP 2008 普及组] ISBN 号码
算法·p1055
程芯带你刷C语言简单算法题24 分钟前
Day28~实现strlen、strcpy、strncpy、strcat、strncat
c语言·c++·算法·c
踏浪无痕36 分钟前
周末拆解:QLExpress 如何做到不编译就能执行?
后端·算法·架构
一个不知名程序员www39 分钟前
算法学习入门--- 树(C++)
c++·算法
如竟没有火炬1 小时前
四数相加贰——哈希表
数据结构·python·算法·leetcode·散列表
背心2块钱包邮1 小时前
第9节——部分分式积分(Partial Fraction Decomposition)
人工智能·python·算法·机器学习·matplotlib
仰泳的熊猫1 小时前
1148 Werewolf - Simple Version
数据结构·c++·算法·pat考试
chao1898441 小时前
MATLAB中的多重网格算法与计算流体动力学
开发语言·算法·matlab