python贪心算法求删数问题_贪心算法—删数问题

给定n位正整数a,去掉其中任意k≤n 个数字后,剩下的数字按原次序排列组成一个新的正整数。对于给定的n位正整数a 和正整数k,设计一个算法找出剩下数字组成的新数最小的删数方案。

算法的原理应该是说从最高位开始,一次向低位搜索,一旦遇到前一位(高位)的数大于当前位,则删去前一位,直到删除k个数,如果到达末尾还没有删除k个,则说明现在这个数已经是从小到大排序了,则从最低位开始删除要求的位数。

#include

#include

int main()

{

char a[20];

int k;

printf("输入正整数:\n");

scanf("%s",a);

printf("输入k值:\n");

scanf("%d",&k);

int len = strlen(a);

while(k--)

{

int i=0,j;

while(i

{

i++;

}

if(i==len-1)//表示字符串是递增的

{

len--;

while(k--)

len--;

break;

}

else

{

for(j=i;j

a[j]=a[j+1];

len--;

}

}

printf("最小值为:\n");

int l;

for(l=0;l

printf("%c",a[l]);

printf("\n");

return 0;

}

0818b9ca8b590ca3270a3433284dd417.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值