
c# 求俩集合的并集
我写了个方法求俩集合的并集,但是感觉不太对,效果不好。分享下简单的方法,详细些!!publicvoidgetCollectionUnion(List<object>one...
我写了个方法求俩集合的并集,但是感觉不太对,效果不好。分享下简单的方法,详细些!!
public void getCollectionUnion(List<object> one ,List<object>two)
{
List<object> result = new List<object>();
for (int i = 0; i < one.Count;i++ )
{
for(int k=0;k<two.Count;k++)
{
if(one[i].Equals(two[k])&&result.Contains(one[i]))
{
result.Add(one[i]);
break;
}
else
{
result.Add(one[i]);
result.Add(two[k]);
}
}
}
} 展开
public void getCollectionUnion(List<object> one ,List<object>two)
{
List<object> result = new List<object>();
for (int i = 0; i < one.Count;i++ )
{
for(int k=0;k<two.Count;k++)
{
if(one[i].Equals(two[k])&&result.Contains(one[i]))
{
result.Add(one[i]);
break;
}
else
{
result.Add(one[i]);
result.Add(two[k]);
}
}
}
} 展开
若以下回答无法解决问题,邀请你更新回答
2个回答
展开全部
if(one[i].Equals(two[k])&&result.Contains(one[i]))
{
result.Add(one[i]);
break;
}
这句话有问题,你比较两集合类,但比较的时候你的result里是空的,所以当one和two里有一样的元素时,这个相同的元素你是加不进去的。
you can change like this:
public void getCollectionUnion(List<object> one ,List<object>two)
{
List<object> result = new List<object>();
//将two 添加到result 中
for (int i = 0; i < two .Count;i++ )
{
result.Add(two [i]);
}
//添加结果中不包含one的项
for (int i = 0; i < one.Count;i++ )
{
if(!result.Contains(one[i]))
{
result.Add(one[i]);
break;
}
}
return result ;
}
没调试过,你自己试试
{
result.Add(one[i]);
break;
}
这句话有问题,你比较两集合类,但比较的时候你的result里是空的,所以当one和two里有一样的元素时,这个相同的元素你是加不进去的。
you can change like this:
public void getCollectionUnion(List<object> one ,List<object>two)
{
List<object> result = new List<object>();
//将two 添加到result 中
for (int i = 0; i < two .Count;i++ )
{
result.Add(two [i]);
}
//添加结果中不包含one的项
for (int i = 0; i < one.Count;i++ )
{
if(!result.Contains(one[i]))
{
result.Add(one[i]);
break;
}
}
return result ;
}
没调试过,你自己试试
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你这个函数求集合的并集,就算求出来怎么获得这个List(函数内部声明的result)。要有返回值吧。。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询