Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
580 views
in Technique[技术] by (71.8m points)

三个人各存有一个随机数,如何在数据不泄漏的情况下计算三个随机数的平均数

面试中遇到一个问题:有三个人,他们每个人各有一个随机数,但是彼此不知道对方
的随机数是多少,三个人之间可相互通信,在保证数据不泄露的情况下,如何能计算
出这三个数的平均数呢?
写出解题思路。
请教一下各位大神时候有相关解题思路呢?面试官给的提示是这个题是可解的。


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

假设三个人分别是 ABC,对应的数字也分别是 abc
A 生成一个随机数 x,然后把 a + x 的结果告诉 B,把 x 告诉 C
B 拿到 a + x,加上 b 后得到 a + b + x ,把结果告诉 C
C 现在拿到了 a + b + x,也知道 xc 的值,就可以通过 (a + b + x + c - x) / 3,得到三个数的平均值。


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...