找水王
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 }
三.实验截图
四.个人总结
以上是关于找水王的主要内容,如果未能解决你的问题,请参考以下文章