子集

题目链接点这里
这里用到定义字符串类型为string q=string.Empty;还有就是将一个数强制类型转换成二进制的方法Convert.ToString(x,n).PadLeft(m,‘0’),x指的是需要转换的数字,n为二进制类型,方法为Convert.ToString(x,n)。另外用到的PadLeft是将转换的n进制数组用向左添加0的方法补充到长度为m,这样就可以通过此来将某一个数字转换成二进制长度为len的字符串。

public class Solution {   
	public IList<IList<int>> Subsets(int[] nums){                
		IList<IList<int>> code = new List<IList<int>>();                
		int len = nums.Length;                
		for (int i = 0; i < Math.Pow(2,len); i++){                    
			List<int> list = new List<int>();                    
			string temp = string.Empty;                    
			temp = Convert.ToString(i, 2).PadLeft(len, '0');                    
			for (int j = 0; j < len; j++){                        
				if (temp[j] == '1'){                            
					list.Add(nums[j]);                        
				}                                         
			}                    
		code.Add(list);                
		}                
		return code;            
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值