PTA 删除重复字符

本题要求编写程序,将给定字符串去掉重复的字符后,按照字符ASCII码顺序从小到大排序后输出。

输入格式:
输入是一个以回车结束的非空字符串(少于80个字符)。

输出格式:
输出去重排序后的结果字符串。

输入样例:

ad2f3adjfeainzzzv

输出样例:

23adefijnvz

 最开始感觉被难住了,看了别人的解法之后茅塞顿开。大致分为以下两步:

  1. 先冒泡排序,按照ASCII码大小排列
  2. 只打印前后字符不相等的字符

 代码如下:

#include <stdio.h>
#include <string.h>
int main()
{
	char a[81];
	gets(a);//读字符串 
	int i,j;
	int len=strlen(a);//字符串长度 
	
	for(i=0;i<len-1;i++)//冒泡排序,最大的“沉底” 
	{
		for(j=0;j<len-1-i;j++)
		{
			if(a[j]>a[j+1])
			{
				char temp;
				temp=a[j];
				a[j]=a[j+1];
				a[j+1]=temp;
			}
		}
	}
	//冒泡排序是“稳定的”排序算法,即a[i]==a[j]时,位置不会交换 
	
	for(i=0;i<len;i++)//遍历字符串,若前后字符不一致就打印 
	{
		if(a[i]!=a[i+1])
			printf("%c",a[i]);
	}

	return 0;
}

  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 答案: 该程序可以使用以下步骤实现: 1. 创建一个空字典,用于存储不重复字符。 2. 遍历给定字符串中的每一个字符,如果不在字典中,则将其存入字典。 3. 对字典中的字符按照ASCII码从小到大排序。 4. 将排序后的字符连接起来,形成新的字符串并输出。 ### 回答2: 对于这道编程题,我们可以采用哈希表的思路来实现。首先,我们需要遍历给定的字符串,将每个字符都插入到哈希表中,并记录下它们在字符串中出现的次数。接着,我们通过哈希表中的键(也就是字符)把所有字符都取出来,存放在一个数组里面。最后,对这个数组进行排序,按照字符的ascii码从小到大的顺序进行排序,然后输出即可。 具体的实现方法如下: 首先,我们定义一个哈希表,用来记录每个字符字符串中出现的次数。可以使用Python中的字典类型来实现: ```python char_count = {} ``` 然后,我们对于给定的字符串,遍历每个字符,把它们插入到哈希表中,如果哈希表中已经有了该字符,就把它的出现次数加1。同时,为了保证最后按照ascii码从小到大排序,我们还需要把每个字符都插入到一个List中: ```python char_set = [] for c in s: if c not in char_count: char_count[c] = 1 char_set.append(c) else: char_count[c] += 1 ``` 接下来,我们对这个List按照ascii码顺序从小到大进行排序: ```python char_set.sort() ``` 最后,我们遍历这个排好序的List,输出每个字符及它出现的次数: ```python for c in char_set: print(c * char_count[c], end='') ``` 完整代码如下: ```python s = input() char_count = {} char_set = [] for c in s: if c not in char_count: char_count[c] = 1 char_set.append(c) else: char_count[c] += 1 char_set.sort() for c in char_set: print(c * char_count[c], end='') ``` 如果我们输入的是字符串"abccddefgghhiijjkkll",则输出结果为: ```python abcdefghijkl ``` 以上就是本题的实现思路和Python代码。该程序可以去除重复字符,并且将剩下的字符按照ascii码从小到大排序,最后输出结果。此外,这个程序还可以处理任何给定的字符串,并且能够高效地实现去重和排序的功能。 ### 回答3: 本题要求编写程序,实现对给定字符串的去重和排序操作。 首先,对字符串中的重复字符进行去除,可以采用哈希表的方式,将每个字符作为键值存储到哈希表中,如果该字符已被存储,则将其删除,最终得到的哈希表即为去重后的字符串。 然后,对去重后的字符串进行排序,可以使用快速排序算法或归并排序算法。这里推荐使用归并排序算法,因为该算法稳定且时间复杂度较低,适用于数据规模较大的情况。 具体实现方法如下: 1. 定义一个哈希表,用于存储去重后的字符串。 2. 遍历给定字符串的每个字符,如果该字符未在哈希表中出现,则将其加入哈希表。如果该字符已在哈希表中出现,则将其删除。 3. 对哈希表中的所有键(字符)进行排序,按照字符ascii码顺序从小到大排列。 4. 遍历排好序的键,将每个键对应的值(出现次数)输出到新字符串中。 代码实现如下: ```python # 定义快排函数 def quick_sort(s): if len(s) <= 1: return s pivot = s[0] # 选取第一个元素作为基准值 left = [] right = [] for i in s[1:]: if i < pivot: left.append(i) else: right.append(i) return quick_sort(left) + [pivot] + quick_sort(right) # 定义归并排序函数 def merge_sort(s): if len(s) <= 1: return s mid = len(s) // 2 left = merge_sort(s[:mid]) right = merge_sort(s[mid:]) i = j = 0 result = [] while i < len(left) and j < len(right): if left[i] < right[j]: result.append(left[i]) i += 1 else: result.append(right[j]) j += 1 result += left[i:] result += right[j:] return result # 主函数 if __name__ == '__main__': s = 'abacdfghijklmnbhjcdfg' # 待处理字符串 new_s = {} # 去重后的字符串 for c in s: if c not in new_s.keys(): new_s[c] = 1 else: del new_s[c] # 将键按ascii码排序 sorted_keys = merge_sort(list(new_s.keys())) result = ''.join([k * new_s[k] for k in sorted_keys]) print(result) ``` 上述代码实现了对给定字符串的去重和排序功能,其中,字符串s是待处理的字符串,new_s是去重后的字符串,sorted_keys是排序后的键,result是最终结果。在实际使用时,可根据具体情况选择快排函数或归并排序函数来对字符键进行排序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值