找水王

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了找水王相关的知识,希望对你有一定的参考价值。

一.设计思路

  1.由于题设中给出条件“水王”的发贴数超过列表中总发贴数的一半(即最少比一半多一个);

  2.假设“水王”的发贴数恰好是总发贴数的一半多一个,而“水王”的贴子是均匀分布在贴子列表中的,即每两个相邻的贴子中总有一个“水王”的贴子;

    a.如果贴子总数为奇数,且每两个相邻贴子中总是“水王”的贴子在前(在后亦然),则最后必然剩下一个“水王”的贴子;

    b.如果贴子总数为偶数,且每两个相邻贴子中总是“水王”的贴子在前(在后亦然),则最后必然剩下两个“水王”的贴子。

  3.如果“水王”的发贴数更多时,则两个相邻贴子都是“水王”的概率更高;

  4.根据以上的分析,可以用一个函数按序号依次将贴子列表中的每两个相邻贴子的ID比较,如果相同,则保留一个ID号存放于一个一维数组中;如果不相同,

则跳过,进行下面两个相邻贴子ID号的比较;

  5.如果所得一维数组中只有一个元素,则该ID号即为“水王”的ID号;如果所得一维数组中超过一个元素,则将该一维数组递归调用比较函数,直到一维数组中只有一个元素。

二.代码实现

 1 #include<iostream>
 2 #include<fstream>
 3 #include<string>
 4 #define N 100
 5 using namespace std;
 6 
 7 string findM(string str[],int num)
 8 {
 9     string real;    //记录查找到的水王ID号
10     string next[N];    //按序号将ID号两两比较,若相同,则将该ID号保留一个存放于next[N]中;若不相同,则跳过
11     int i;
12     int length=0;    //记录每次生成的数组next的长度
13     for (i = 0; i < num; i+=2)
14     {
15         if ((str[i] == str[i + 1]&&i+1<num)||i+1==num)
16         {
17             next[length] = str[i];
18             length++;
19         }
20     }
21     //当数组next中只有一个元素时,该元素即为所找水王
22     if (length == 1)
23     {
24         real = next[0];
25     }
26     else
27     {
28         real=findM(next, length);
29     }
30     return real;
31 }
32 
33 int main()
34 {
35     ifstream file("myfile.txt");
36     int num[N];    //存放序号
37     string str[N];    //存放各序号对应的ID号
38     string gfind;    //获得的水王的ID号
39     int n=0;    //存放发帖表行数
40     while (file>>num[n]>>str[n])
41     {
42         n++;
43     }
44     cout << "发帖表信息:" << endl;
45     cout << "序号\\t贴主ID号" << endl;
46     for (int i = 0; i < n; i++)
47     {
48         cout << num[i] << "\\t"<<str[i]<<endl;
49     }
50     gfind=findM(str, n);
51     cout << "\\n";
52     cout << "水王是:";
53     cout << gfind << endl;
54     file.close();
55     return 0;
56 }

三.实验截图

技术分享

技术分享

四.个人总结

以上是关于找水王的主要内容,如果未能解决你的问题,请参考以下文章

找水王

找水王2

找水王续

课堂练习-找水王

找水王2

课堂练习--找水王