日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

UVA 1152 4 Values Whose Sum is Zero 和为0的4个值 (中途相遇)

發布時間:2025/3/15 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 UVA 1152 4 Values Whose Sum is Zero 和为0的4个值 (中途相遇) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

摘要:中途相遇。對比map,快排+二分查找,Hash效率。

?

n是4000的級別,直接O(n^4)肯定超,所以中途相遇法,O(n^2)的時間枚舉其中兩個的和,O(n^2)的時間枚舉其他兩個的和的相反數,然后O(logN)的時間查詢是否存在。

首先試了下map,果斷TLE

//TLE #include<cstdio> #include<algorithm> #include<map> using namespace std;const int maxn = 4001; int data[4][maxn];map<int,int> cnt;int main() {int T ; scanf("%d",&T);int *A = data[0], *B = data[1], *C = data[2],*D = data[3];map<int,int>::iterator it;while(T--){int n; scanf("%d",&n);for(int i = 0; i < n; i++){scanf("%d%d%d%d",A+i,B+i,C+i,D+i);}for(int i = 0; i < n; i++)for(int j = 0; j < n; j++){cnt[A[i]+B[j]]++;}int ans = 0;for(int i = 0; i < n; i++)for(int j = 0; j < n; j++){int tmp = -C[i]-D[j];it = cnt.find(tmp);if(it!=cnt.end()) ans += it->second;}printf("%d\n",ans);if(T) putchar('\n');}return 0; } map,TLE

然后改成了快排+二分查找,4920ms

// runtime 4920ms #include<cstdio> #include<algorithm> using namespace std;const int maxn = 4001; int data[4][maxn]; int vec[maxn*maxn];int _lower_bound(int *A,int L,int R,int v) {int m;while(L<R){m = (L+R)>>1;if(A[m]>=v) R = m;else L = m+1;}return L; }int _upper_bound(int *A,int L,int R,int v) {int m;while(L<R){m = (L+R)>>1;if(A[m]>v) R = m;else L = m+1;}return L; }int main() {int T ; scanf("%d",&T);int *A = data[0], *B = data[1], *C = data[2],*D = data[3];while(T--){int n; scanf("%d",&n);for(int i = 0; i < n; i++){scanf("%d%d%d%d",A+i,B+i,C+i,D+i);}int sz = 0;for(int i = 0; i < n; i++)for(int j = 0; j < n; j++){vec[sz++] = A[i]+B[j];}sort(vec,vec+sz);int ans = 0;for(int i = 0; i < n; i++)for(int j = 0; j < n; j++){int tmp = -(C[i]+D[j]);ans += _upper_bound(vec,0,sz,tmp) - _lower_bound(vec,0,sz,tmp);}printf("%d\n",ans);if(T) putchar('\n');}return 0; } 快拍+二分,4920ms

實際上沒有必要每次二分查找,用兩個指針,兩邊都從最小的數開始比較。

快排+計數,2832ms

#include<cstdio> #include<algorithm> #include<map> using namespace std; typedef pair<int,int> pii; #define fi first #define se second const int maxn = 4001; int data[4][maxn];pii cnt1[maxn*maxn]; pii cnt2[maxn*maxn]; int vec[maxn*maxn];int main() {int T ; scanf("%d",&T);int *A = data[0], *B = data[1], *C = data[2],*D = data[3];while(T--){int n; scanf("%d",&n);for(int i = 0; i < n; i++){scanf("%d%d%d%d",A+i,B+i,C+i,D+i);}int sz = 0;for(int i = 0; i < n; i++)for(int j = 0; j < n; j++){vec[sz++] = A[i]+B[j];}sort(vec,vec+sz);int len1 = 0;cnt1[len1] = pii(vec[len1],1);for(int i = 1; i < sz; i++){if(vec[i] == cnt1[len1].fi) cnt1[len1].se++;else { cnt1[++len1].fi = vec[i]; cnt1[len1].se = 1; }}sz = 0;for(int i = 0; i < n; i++)for(int j = 0; j < n; j++){vec[sz++] = -C[i]-D[j];}sort(vec,vec+sz);int len2 = 0;cnt2[len2] = pii(vec[len2],1);for(int i = 1; i < sz; i++){if(vec[i] == cnt2[len2].fi) cnt2[len2].se++;else { cnt2[++len2].fi = vec[i]; cnt2[len2].se = 1; }}int p = 0,q = 0,ans = 0;while(p<=len1&&q<=len2){if(cnt1[p].fi == cnt2[q].fi){ans += cnt1[p++].se*cnt2[q++].se;}else if(cnt1[p].fi>cnt2[q].fi) q++;else p++;}printf("%d\n",ans);if(T) putchar('\n');}return 0; } 快排+計數

還有Hash表,寫掛了,待補。。。

?

轉載于:https://www.cnblogs.com/jerryRey/p/4692021.html

總結

以上是生活随笔為你收集整理的UVA 1152 4 Values Whose Sum is Zero 和为0的4个值 (中途相遇)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 深夜精品 | 美女被草视频在线观看 | 国产精品videossex久久发布 | 精品国产大片大片大片 | 日韩三级av| 国产精品国产三级国产三级人妇 | 男人av影院 | 亚洲视频一区二区三区四区 | 草草国产 | 性——交——性——乱免费的 | 青青草视频在线看 | 日韩性爰视频 | 青草久久久 | 男人天堂视频在线观看 | 国产精品国产自产拍高清av | 精品日韩在线观看 | 国产av成人一区二区三区 | 欧美熟妇乱码在线一区 | 成人欧美一区二区三区在线播放 | 2019天天干| 成品短视频泡芙 | 99精品视频国产 | 国产在线精品自拍 | 国产清纯白嫩初高中在线观看性色 | 一级毛毛片 | www.国产高清 | 国产日韩精品一区二区 | 丰满人妻熟女aⅴ一区 | 久久99精品久久久久久国产越南 | 欧美黑粗硬| av一区二区在线播放 | 国产第一区第二区 | 欧美一级在线免费观看 | 亚洲成人免费在线观看 | 99热免费 | 欧美做爰全过程免费观看 | 日韩精品一区二区三区无码专区 | 亚洲天堂男人天堂 | 亚洲一区二区三区午夜 | 久久精品视频8 | 一级黄av | 秘密基地免费观看完整版中文 | 综合成人| 亚洲av无码国产在丝袜线观看 | 成人av片免费看 | 国产后入又长又硬 | 欧美a级在线观看 | 中文字幕乱码人妻无码久久95 | www.av视频在线观看 | 国产探花视频在线观看 | 特级做a爰片毛片免费69 | 国产精品99久久久久久久女警 | 国产精品久久久久久久成人午夜 | 欧美日韩aa | 国产午夜视频在线播放 | 国产911| 偷拍视频一区二区 | 欧美91精品 | 国产女人高潮视频 | 欧美性受xxxx黑人猛交88 | 亚洲AV无码成人精品国产一区 | 91免费国产在线观看 | 毛片免费一区二区三区 | 人人澡人人透人人爽 | 亚洲人免费 | 日韩专区一区二区三区 | 1024精品一区二区三区日韩 | 日日爱av| 激情婷婷丁香 | 在线免费av网址 | 无码熟妇人妻av | 青青在线观看视频 | 91人人视频 | 狠狠久| 日本h视频在线观看 | 国产精品无码中文字幕 | 一级大黄毛片 | 成人午夜av | 污污视频在线观看网站 | 日韩精品无 | 亚洲最大福利网站 | 久久免费播放视频 | 法国空姐在线观看免费 | aaaaa一级片 色图社区 | 国产精品嫩草久久久久 | 欧美久久久久久久 | 成人黄色小说视频 | 色哟哟在线观看 | 久久久涩| 无码人妻丰满熟妇啪啪网站 | 天天色官网| 国产精品午夜久久 | 欧美福利一区二区 | 欧美老女人性视频 | 在线观看免费av网站 | 青青草国产在线播放 | 久久九九免费视频 | 黄色一级网址 | 免费看黄色网 |