从终端输入一个字符串,然后删除字符串中出现次数最少的字符

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


#define N 100


del_min(char *str,int *len_str) //调用函数有两个形参,一个char类型,一个int类型
{
int i = 0;  
int j = 0;                               
int k = 0; //定义并初始化三个循环变量
int count = 0;                            //定义并初始化一个计数变量
int min_max = 100;                          //定义需要删除的数组的最大存放限度,即N的大小
int temp[N] = {0};                        //定义并初始化一个中间数组用来储存需要删除的下标

for(i = 0; i < (int) len_str; i++)          //外层函数遍历数组所有内容,(int) len_str强制类型转换为整型   
{
count = 0;                    //初始化计数变量

for(j = 0; j < (int) len_str; j++)      //内层循环用来进行比较是否出现同样的字符     
{
if(*(str + i) == *(str + j))
{
count++; //计数变量自增,比较出同样的字符,进行计数
}
}
if(count == min_max) //如果计数变量为min_max说明全为同一字符
{
k++;                          
temp[k] = i; //全部赋给中间数组进行删除
}
if(count < min_max) //如果小于min_max,min_max进行重新赋值,k=0中间数组首位
{
min_max = count;
k = 0;                              
temp[k] = i;
}
}

k = 0; //初始化k,以便下面的循环从中间数组的首位进行比较

for(i = 0; i < (int) len_str; i++)
{
if(i == temp[k])
{
*(str + i) = '\0';                 //删除中间数组
k++;
}
}

for(i = 0; i < (int) len_str; i++) //循环打印最终数组
{
printf("%c",str[i]);                      
}

printf("\n");

*str = '\0'; //在最后加上'\0',结束数组
}


int main()
{
int len_str = 0; //定义并初始化数组长度为0

char str[N] = "0"; //定义并初始化数组

printf("Please input a string:\n");
scanf("%s",str); //输入一个字符串

len_str = strlen(str); //表示字符串长度

del_min(str,(int*)len_str); //调用函数del_min,加上(int*)强制类型转换为指针

return 0;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值