两个string数组对应比较
最近做的array string类型对比。这个可能比较复杂,用的是linq 是请教别人的,我在这里记录一下
jquery 方法里面的数组
function arrtxt() {
var arrt= [];
arrt.push('测试', '女', '124563', '');
arrt.push('小城市', '女', '8593431', '66867857857');
arrt.push('小路与', '男', '8593431', '498464');
var arrs = [];
arrs.push('小于', '女', '123123123', '' );
arrs.push('小城市', '女', '8593431', '66867857857');
arrs.push('小周', '男', '8593431', '498464');
$.ajax({
url: "ArrList.ashx?opt=arr&arrt=" + arrt+ "&arrs =" + arrs ,
type: "post",
success: function (date) {
var u = $.parseJSON(date);
var kref = u.ker
var tdker = u.td
var tab="<table>";
for (var i = 0; i< kref.length; i++) {
tab="<tr><td><span>" + kref[i].krname + "</span></td。";
tab+= "<td> <span>" + kref[i].krvisa + "</span></td></tr>";
}
tab+="</table>";
}
后台ashx页面
获取页面参数
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
context.Response.Charset = "utf-8"; string opt = context.Request.Params["opt"].ToString().Trim();
string html = "";
switch (opt)
{
case "arr":
html = Getarr(context);
break;
}
context.Response.Write(htm);
}
获取的参数
#region Astring数组对比
public string GetArr(HttpContext context)
{
JObject jo = new JObject();
JObject jotd = new JObject();
JObject jakr = new JObject();
string[] arrkr = new string[] {};
#region
string kerens = "";
if (!string.IsNullOrEmpty(context.Request.Params["arrt"]))
{
kerens = context.Request.Params["krres"].ToString().Trim();
if (kerens.Length > && kerens != "")
{
arrkr = kerens.Split(',');
}
}
string tdcz = "";
string[] arrtd = new string[] { };
if (!string.IsNullOrEmpty(context.Request.Params["arrs"]))
{
tdcz = context.Request.Params["tdds"].ToString().Trim();
if (tdcz.Length > && tdcz != "")
{
arrtd = tdcz.Split(',');
}
}
List<string> arrkrsd = new List<string>();
string[] krstr = new string[] { };
for (int i = , j = ; i < Math.Ceiling(arrkr.Length / 4m); i++, j = j + )
{
krstr = (SplitArray(arrkr, j, ));
arrkrsd.Add(krstr[] + "," + krstr[] + "," + krstr[] + "," + krstr[] );
arrkrsd.ToArray();
}
var krsd = arrkrsd.Distinct().ToArray();
List<string> arrtdsd = new List<string>();
string[] tdstr = new string[] { };
for (int i = , j = ; i < Math.Ceiling(arrtd.Length / 4m); i++, j = j + )
{
tdstr = (SplitArray(arrtd, j, ));
arrtdsd.Add(tdstr[] + "," + tdstr[] + "," + tdstr[] + "," + tdstr[] );
arrtdsd.ToArray();
}
var tdsd=arrtdsd.Distinct().ToArray();
var combine =
krsd.Concat(tdsd) // 合并
.Distinct() // 去掉重复项
.ToArray(); // 通过Linq进行left join, 得到数组A
var Kre =
(from cItem in combine
join aItem in krsd on cItem equals aItem into ps
from p in ps.DefaultIfEmpty()
select p).ToArray(); // 通过Linq进行left join, 得到数组B
var TD =
(from cItem in combine
join bItem in tdsd on cItem equals bItem into ps
from p in ps.DefaultIfEmpty()
select p).ToArray(); JObject newkr = new JObject();//新——客人
JObject newtd = new JObject();//新——团队
JArray jkt = new JArray();//新—客人
JArray jtd = new JArray();//新——团队
string[] ku = new string[] { };
for (int i = ; i < Kre.Length; i++)
{
newkr = new JObject();//新——客人
ku = new string[] { };
string j = Kre[i];
if (string.IsNullOrEmpty(j))
{
newkr.Add("krname", "");
newkr.Add("krsex", "");
newkr.Add("krmobile", "");
newkr.Add("krsfz", "");
}
else
{
ku = j.Split(',');
newkr.Add("krname", ku[]);
newkr.Add("krsex", ku[]);
newkr.Add("krmobile", ku[]);
newkr.Add("krsfz", ku[]);
}
jkt.Add(newkr);
}
string[] kutt = new string[] { };
for (int k = ; k < TD.Length; k++)
{
newtd = new JObject();//新——团队
kutt = new string[] { };
string ty = TD[k];
if (string.IsNullOrEmpty(ty))
{
newtd.Add("tdname", "");
newtd.Add("tdsex", "");
newtd.Add("tdmobile", "");
newtd.Add("tdsfz", ""); }
else
{
kutt = ty.Split(',');
newtd.Add("tdname", kutt[]);
newtd.Add("tdsex", kutt[]);
newtd.Add("tdmobile", kutt[]);
newtd.Add("tdsfz", kutt[]);
}
jtd.Add(newtd);
}
jo.Add("ker", jkt);
jo.Add("td", jtd); return jo.ToString(); }
//分隔数组
public static string[] SplitArray(string[] Source, int StartIndex, int Len)
{
string[] result = new string[Len];
for (int i = ; i < Len; i++)
{
result[i] = i + StartIndex > Source.Length - ? "" : Source[i + StartIndex];
}
return result;
}
#endregion
后台ashx
<span>" + ker[w].krname + "</span>
<span>" + td[w].tdname+ "</span>
#region 客人名单对比 public string GetContrast(HttpContext context) { JObject jo = new JObject(); JObject jotd = new JObject(); JObject jakr = new JObject(); string[] arrkr = new string[] {}; #region string kerens = "";//客人名单 if (!string.IsNullOrEmpty(context.Request.Params["krres"])) { kerens = context.Request.Params["krres"].ToString().Trim(); if (kerens.Length > 0 && kerens != "") { arrkr = kerens.Split(','); } } string tdcz = "";//客人名单 string[] arrtd = new string[] { }; if (!string.IsNullOrEmpty(context.Request.Params["tdds"])) { tdcz = context.Request.Params["tdds"].ToString().Trim(); if (tdcz.Length > 0 && tdcz != "") { arrtd = tdcz.Split(','); } } List<string> arrkrsd = new List<string>(); string[] krstr = new string[] { }; for (int i = 0, j = 0; i < Math.Ceiling(arrkr.Length / 10m); i++, j = j + 10) { krstr = (SplitArray(arrkr, j, 10)); arrkrsd.Add(krstr[0] + "," + krstr[1] + "," + krstr[2] + "," + krstr[3] + "," + krstr[4] + "," + krstr[5] + "," + krstr[6] + "," + krstr[7] + "," + krstr[8] + "," + krstr[9]); arrkrsd.ToArray(); } var krsd = arrkrsd.Distinct().ToArray(); List<string> arrtdsd = new List<string>(); string[] tdstr = new string[] { }; for (int i = 0, j = 0; i < Math.Ceiling(arrtd.Length / 10m); i++, j = j + 10) { tdstr = (SplitArray(arrtd, j, 10)); arrtdsd.Add(tdstr[0] + "," + tdstr[1] + "," + tdstr[2] + "," + tdstr[3] + "," + tdstr[4] + "," + tdstr[5] + "," + tdstr[6] + "," + tdstr[7] + "," + tdstr[8] + "," + tdstr[9]); arrtdsd.ToArray(); } var tdsd=arrtdsd.Distinct().ToArray(); var combine = krsd.Concat(tdsd) // 合并 .Distinct() // 去掉重复项 .ToArray();
// 通过Linq进行left join, 得到数组A var Kre = (from cItem in combine join aItem in krsd on cItem equals aItem into ps from p in ps.DefaultIfEmpty() select p).ToArray();
// 通过Linq进行left join, 得到数组B var TD = (from cItem in combine join bItem in tdsd on cItem equals bItem into ps from p in ps.DefaultIfEmpty() select p).ToArray();
JObject newkr = new JObject();//新——客人 JObject newtd = new JObject();//新——团队 JArray jkt = new JArray();//新—客人 JArray jtd = new JArray();//新——团队 string[] ku = new string[] { }; for (int i = 0; i < Kre.Length; i++) { newkr = new JObject();//新——客人 ku = new string[] { }; string j = Kre[i]; if (string.IsNullOrEmpty(j)) { newkr.Add("krname", ""); newkr.Add("krsex", ""); newkr.Add("krmobile", ""); newkr.Add("krsfz", ""); newkr.Add("krvisa", ""); newkr.Add("krtypepass", ""); newkr.Add("kren", ""); newkr.Add("krcountry", ""); newkr.Add("krhit", ""); newkr.Add("krguestuu", "");
} else { ku = j.Split(','); newkr.Add("krname", ku[0]); newkr.Add("krsex", ku[1]); newkr.Add("krmobile", ku[2]); newkr.Add("krsfz", ku[3]); newkr.Add("krvisa", ku[4]); newkr.Add("krtypepass", ku[5]); newkr.Add("kren", ku[6]); newkr.Add("krcountry", ku[7]); newkr.Add("krhit", ku[8]); newkr.Add("krguestuu", ku[9]); } jkt.Add(newkr); } string[] kutt = new string[] { }; for (int k = 0; k < TD.Length; k++) { newtd = new JObject();//新——团队 kutt = new string[] { }; string ty = TD[k]; if (string.IsNullOrEmpty(ty)) { newtd.Add("tdname", ""); newtd.Add("tdsex", ""); newtd.Add("tdmobile", ""); newtd.Add("tdsfz", ""); newtd.Add("tdvisa", ""); newtd.Add("tdtypepass", ""); newtd.Add("tden", ""); newtd.Add("tdcountry", ""); newtd.Add("tdhit", ""); newtd.Add("tdguestuu", "");
} else { kutt = ty.Split(','); newtd.Add("tdname", kutt[0]); newtd.Add("tdsex", kutt[1]); newtd.Add("tdmobile", kutt[2]); newtd.Add("tdsfz", kutt[3]); newtd.Add("tdvisa", kutt[4]); newtd.Add("tdtypepass", kutt[5]); newtd.Add("tden", kutt[6]); newtd.Add("tdcountry", kutt[7]); newtd.Add("tdhit", kutt[8]); newtd.Add("tdguestuu", kutt[9]); } jtd.Add(newtd); } #endregion #region //string kr = ""; // string dt = ""; // string zo = ""; //int cont = (arrtdsd.Count) + (arrkrsd.Count); //string[] xarr = new string[cont]; //arrkrsd.CopyTo(xarr, 0); //arrtdsd.CopyTo(xarr, arrkrsd.Count);//将两个数组合并为一个新数组 //List<string> list = new List<string>(); //for (int i = 0; i < xarr.Length; i++)//删除重复元素 //{ // if (list.IndexOf(xarr[i].ToLower()) == -1) // list.Add(xarr[i]); //} //for (int i = 0; i < list.Count; i++) //{ // bool tl = false; // zo = list[i].ToString(); // int a = zo.IndexOf(","); // string li = ""; // li = zo.Substring(0, a); // if (arrkrsd.Count > arrtdsd.Count) // {
// for (int j = 0; j < arrkrsd.Count; j++) // { // kr = arrkrsd[j].ToString(); // int n = kr.IndexOf(","); // string krtt = ""; // krtt = kr.Substring(0, n); // if (li == krtt) // { // tl = true; // newkr.Add("" + i + "", arrkrsd[j]); // } // if (tl == false) // { // newkr.Add("" + i + "", "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + ""); // } // } // for (int t = 0; t < arrtdsd.Count; t++) // { // dt = arrtdsd[t].ToString(); // int tt = dt.IndexOf(","); // string dttt = ""; // dttt = dt.Substring(0, tt); // if (kr == dttt) // { // tl = true; // newtd.Add("" + i + "", arrtdsd[t]); // } // if (tl == false) // { // newtd.Add("" + i + "", "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + "" + "," + ""); // } // } // } // else // { // for (int j = 0; j < arrtdsd.Count; j++) // { // dt = arrtdsd[j].First().ToString(); // for (int t = 0; t < arrkrsd.Count; t++) // { // kr = arrkrsd[t].First().ToString(); // if (dt == kr) // { // tl = true; // newkr.Add(arrkrsd[t]); // newtd.Add(arrtdsd[j]); // } // } // if (tl == false) // { // newtd.Add(arrtdsd[j]); // }
// } // } //} #endregion jo.Add("ker", jkt); jo.Add("td", jtd); return jo.ToString();
} //分隔数组 public static string[] SplitArray(string[] Source, int StartIndex, int Len) { string[] result = new string[Len]; for (int i = 0; i < Len; i++) { result[i] = i + StartIndex > Source.Length - 1 ? "" : Source[i + StartIndex]; } return result; } #endregion
两个string数组对应比较的更多相关文章
- 取两个String数组的交集
import org.testng.annotations.Test; import java.util.HashMap; import java.util.LinkedList; import ja ...
- 【.net】从比较两个字节数组谈起
上午,有位初学者朋友问:如何比较两个字节数组中各字节是否相等? 不许笑,我一向反对嘲笑初学者,初学者不认真学习时你可以批评,但不能讥嘲.你不妨想想,你自己开始学习编程的时候又是什么个光景? 好,于是, ...
- [转载]寻找两个有序数组中的第K个数或者中位数
http://blog.csdn.net/realxie/article/details/8078043 假设有长度分为为M和N的两个升序数组A和B,在A和B两个数组中查找第K大的数,即将A和B按升序 ...
- 关于String类和String[]数组的获取长度方法细节
一.在Java中,以下代码段有错误的是第( )行 public static void main(String[] args) { String name = "小新"; ...
- 【递归打卡2】求两个有序数组的第K小数
[题目] 给定两个有序数组arr1和arr2,已知两个数组的长度分别为 m1 和 m2,求两个数组中的第 K 小数.要求时间复杂度O(log(m1 + m2)). [举例] 例如 arr1 = [1, ...
- Leetcode#88. Merge Sorted Array(合并两个有序数组)
题目描述 给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组. 说明: 初始化 nums1 和 nums2 的元素数量分别为 m ...
- 两个有序数组长度分别为m,n,最多m+n次查找找出相同的数
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- vb中去掉string数组的一部分
今天碰到一个问题,登陆的时候,如果不需要验证手机号为空,则不去验证手机号 因为登陆的时候所有的验证信息都存放在一个数组里 Dim CheckUserInfo() As String ={UserBir ...
- leetcode实践:找出两个有序数组的中位数
题目 给定两个大小为 m 和 n 的有序数组 nums1 和 nums2. 请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n)). 代码实现 package com. ...
随机推荐
- Python读入与写出中文时出现乱码
解决办法:重置sys模块,设置默认编码方式为utf-8. 在.py文件的开头添加下面两行代码: reload(sys) sys.setdefaultencoding('utf8')
- 文件:一个任务 - 零基础入门学习Python029
文件:一个任务 让编程改变世界 Change the world by program 一个任务 这节课,我们需要一起来完成一个任务:将文件(record.txt)中的数据进行分割并按照以下规律保存起 ...
- Qt5+VS2013兼容XP方法
用Qt5+VS2013编译程序默认配置会在XP运行时报"不是有效的Win32程序"工作需要必须要XP运行 pro文件中加一句: 复制代码 QMAKE_LFLAGS_WINDOWS ...
- Qt编程之信号与槽-------unresolved external symbol "public: virtual struct QMetaObject const * __thiscall XX::metaObject(void)const
原因是加入Q_OBJECT这个macro的类,被编译的时候就要用到moc这个命令,所以在VS2010中,没有加入此命令的应用,当然会出错了.所以解决办法是加,或者如果你不使用信号槽可以直接删除. 当要 ...
- Android自定义日历,可以点击、标注日期、节气、旧历等
1. [图片] 9A59974C-47D4-47E3-8136-3F873EB9BBDC.jpg 2. [图片] left_arrow_pre.png 3. [图片] left_arrow.png 4 ...
- 【转】【Android】HAL分析
原文网址:http://www.cnblogs.com/lcw/p/3335505.html HAL概述 以下是基于android4.0.3,对应其他低版本的代码,可能有所差异,但基本大同小异. An ...
- HashMap非线程安全分析
通过各方资料了解,HashMap不是线程安全的,但是为什么不是线程安全的,在什么情况下会出现问题呢? 1. 下面对HashMap做一个实验,两个线程,并发写入不同的值,key和value相同,最后再看 ...
- 发几个速度快可以用的google IP,谷歌IP(转)
google搜索引擎打不开时的解决办法,谷歌(google)的IP是多少? google IP镜像. 这里搜集了几个经过测试可用的IP,用来在不能域名访问google的时候进行访问,实时更新! 前面几 ...
- Java vs Python
面试时常问到这两种语言的区别,在此总结一下. Referrence: Udemy:python-vs-java Generally, Python is much simpler to use, an ...
- linux 网络Socket实战
Preface:就算调通API,也不值得太过自豪!!!悉心细心学习,最好的深度学习就是看-学...*.h/*.class ProtoType; 1,linux C ftp C/S简单实现 ftpS端码 ...