算法分析---删除字符串中出现次数最少的字符

编写一个函数,删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除。输出删除这些单词后的字符串。字符串中其他字符保持原来的顺序。 格式说明: 字符串仅仅包括字母。不可能为空串,不包括空格,单词仅仅由小写英文字母组成。输入的字符串长度不会超过20个char 。

算法思路:

(1)定义一个长度为26的整型数组

下标从0-25分别表示a-z这26个小写字母,用来保存字符串中各个字符出现的次数

(由于‘a’-‘a’=0,‘z’-‘a’=25刚好与数组的下标相应)

“abcdddeeffffxxyz”各个字符出现的次数例如以下图所看到的:

(2)求出数组中的最小值即字符串中字符出现的最小次数min(找出数组中第一个不为零的值。从前往后去比較大小。找出最小值)。

(3)定义一个空字符数组用来保存新字符串(将出现次数大于min的字符依照顺序存入空数组中。并在末尾加上字符串结束标志‘\0‘)。

(4)算法结束。

#include <stdio.h>
#include <string.h>
#include <malloc.h>

char * change(char *str){
	int alpha[26]={0}; //定义并初始化长度为26的字符数组,用来保存各个小写字母出现的次数
	int len = strlen(str); //字符串的长度
	for(int i = 0 ; i< len ; i++){ //遍历字符串中的字符
		int index = str[i]-‘a‘;  //字符在alpha数组中的下标
		alpha[index]++; //次数+1
	}
//经过以上代码。已经将各个小写字母出现的次数保存在alpha数组中

	int min = 0;
	for(i = 0 ; i < len ; i++){ //求出数组中第一个不为零的值
		if(alpha[i]!=0)
			min = alpha[i];
	}

	for(i = 0 ; i < 26 ; i++){ //求出alpha数组中最小元素即小写字母中出现的最小次数
		if(alpha[i]!=0 && alpha[i]<min){
			min = alpha[i];
		}
	}

	char * newStr = (char *)malloc(sizeof(char) * len); //用来保存改变后的字符串
	char *p = str;
	int num=0;
	while(*p){ //遍历字符串,将出现次数大于min的字符串保存到newStr中
		int index2 = *p-‘a‘;
		if(alpha[index2]!=min){
			newStr[num] = *p;
			num++;
		}
		p++;
	}
	newStr[num]=‘\0‘;
	return newStr;
}
void main(){
	char str[100];  //保存输入的字符串
	gets(str); //从键盘输入字符串
	char *res = change(str);
	puts(res);
	free(res);
}
时间: 2024-12-16 09:24:56

算法分析---删除字符串中出现次数最少的字符的相关文章

删除字符串中出现次数最少的字符

题目描述 实现删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除.输出删除这些单词后的字符串,字符串中其它字符保持原来的顺序. 输入描述: 字符串只包含小写英文字母, 不考虑非法输入,输入的字符串长度小于等于20个字节. 输出描述: 删除字符串中出现次数最少的字符后的字符串. 输入例子: abcdd 输出例子: dd 思路:(我的思路有点绕弯,先记录下来,后面有网友简洁思路),首先把字符串元素存入list中,继续以key-字符,value-出现次数存入map中,然后map按照val

31:删除字符串中出现次数最少的字符

题目描述 实现删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除.输出删除这些单词后的字符串,字符串中其它字符保持原来的顺序. 输入描述:字符串只包含小写英文字母, 不考虑非法输入,输入的字符串长度小于等于20个字节. 输出描述:删除字符串中出现次数最少的字符后的字符串. 输入例子: abcdd 输出例子: dd 思路:统计各个字符出现的次数,放在LinkedHashMap里,可以把values取出来放到一个collection里,直接调用collection的min()得到出现次

算法基础:删除字符串中出现次数最少的字符(Golang实现)

描述: 实现删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除.输出删除这些单词后的字符串, 字符串中其它字符保持原来的顺序. 输入: 字符串只包含小写英文字母, 不考虑非法输入,输入的字符串长度小于等于20个字节. 输出: 删除字符串中出现次数最少的字符后的字符串. 样例输入: abcdd 样例输出: dd 代码实现 package huawei import ( "fmt" ) func Test4Base() { s := "abcfbcca"

[华为上机练习题]7.删除字符串中出现次数最少的字符

题目 描述: 实现删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除.输出删除这些单词后的字符串,字符串中其它字符保持原来的顺序. 题目类别: 字符串 难度: 中级 运行时间限制: 10Sec 内存限制: 128MByte 阶段: 入职前练习 输入: 字符串只包含小写英文字母, 不考虑非法输入,输入的字符串长度小于等于20个字节. 输出: 删除字符串中出现次数最少的字符后的字符串. 样例输入: abcdd 样例输出: dd 代码 /*------------------------

华为OJ在线软件训练题——删除字符串中出现次数最少的字符(中级)

删除字符串中出现次数最少的字符 描述: 实现删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除. 输出删除这些单词后的字符串,字符串中其它字符保持原来的顺序. 题目类别: 字符串 难度: 中级 分数:   运行时间限制: 10 Sec 内存限制: 128 MByte 阶段: 招聘管理 输入: 字符串只包含小写英文字母, 不考虑非法输入,输入的字符串长度小于等于20个字节. 输出: 删除字符串中出现次数最少的字符后的字符串. 样例输入: abcdd 样例输出: dd 对于此类题目,简

华为机试:删除字符串中出现次数最少的字符

题目描述 实现删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除.输出删除这些单词后的字符串,字符串中其它字符保持原来的顺序. 输入描述: 字符串只包含小写英文字母, 不考虑非法输入,输入的字符串长度小于等于20个字节. 输出描述: 删除字符串中出现次数最少的字符后的字符串. 示例1 输入 abcdd 输出 dd Java:用两个数组来记录各个字符的个数,一个用来排序找出最小的字符出现次数,一个用来决定是否输出当前字符. 1 import java.util.Arrays; 2 i

【华为OJ】【022-删除字符串中出现次数最少的字符】

[华为OJ][算法总篇章] [华为OJ][022-删除字符串中出现次数最少的字符] [工程下载] 题目描述 实现删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除.输出删除这些单词后的字符串,字符串中其它字符保持原来的顺序. 输入描述 字符串只包含小写英文字母, 不考虑非法输入,输入的字符串长度小于等于20个字节. 输出描述 删除字符串中出现次数最少的字符后的字符串. 输入例子 abcdd 输出例子 dd 算法实现 import java.util.*; /** * Author:

实现一个算法,寻找字符串中出现次数最少的、并且首次出现位置最前的字符

<!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8"> <title>test</title> <script> // 获取字符串中出现次数最少的字符 function getRareChar(str) { let hash = {}; // 将各个字符名字.首次出现位置及出现次数存到hash表 for(le

找出字符串中出现次数最多的字符,和最大次数

/*找出字符串中出现次数最多的字符,和最大次数*/ function countMax(str){ var max = 0; // 记录出现的最大次数 var maxChar = ""; // 记录出现最多次数的字符 var counts = new Array(127); // 记录中间计算结果 for(var i = 0; i < counts.length; i++){ counts[i] = 0; } for(var i = 0; i < str.length; i