java练习

1. 编程解决如下问题(50分)。
请在整数n=742683613984中删除8个数字,使得余下的数字按原次序组成的新数最小。要求如下:
(1)整数n和删除数字的个数“8”在源程序中完成赋值,程序直接输出运行结果;
(2)程序结果输出先后被删除的数字(之间以逗号分隔)和删除后所得的最小数。
(提示:整数n可以以字符数组的方式定义、赋值和处理)  

import java.util.Scanner;
public class test_5 {
	static long min=Long.MAX_VALUE;
	public static void play(int n,int temp[],int[] num,int limit){
		if(n==num.length){
			String tempStr="";
			for(int i=0;i<n;i++)
			tempStr+=(temp[i]*num[i]+"").equals("0")?"":temp[i]*num[i]+"";
             if(!tempStr.equals("")&&tempStr.length()==(num.length-limit))
            	if(min>Long.parseLong(tempStr))
        	      min=Long.parseLong(tempStr);
			return;
		}
		for(int i=0;i<2;i++){
			temp[n]=i;
			int count=0;
			for(int j=0;j<n;j++)
				if(temp[j]==1){
				 count++;
				}			
			if(count>num.length-limit)continue;
			play(n+1,temp,num,limit);
		}
	}
	public static void main(String[] args) {
		Scanner input=new Scanner(System.in);
		int num[]={7,4,2,6,8,3,6,1,3,9,8,4};
		System.out.print("删除几个数:");
		int limit=input.nextInt();
		int temp[]=new int[num.length];
	         play(0,temp,num,limit);
		System.out.println(min);
	}
}



 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值