课堂练习-找水王续

1.题目。

三人行设计了一个灌水论坛。信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子。坊间风闻该“水王”发帖数目超过了帖子数目的一半。
如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗?(参考核心代码)
随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID。据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗?

2.设计思想。

通过消除的方法实现,分别将三个连续的ID存到 counter[0],counter[1],counter[2]中,再检测第四个数,如果与前面三个数不同,每个counter都减一,否则相同的counter加一。一直检测到最后一个id。

3.代码。

#include<iostream.h>
#include <stdlib.h>
int main()
{
    int length;
    int Idnum[3]={0,0,0};
    int ID[3]={0,0,0};
    cout<<"请输入总帖子数量:"<<endl;
    cin>>length;
    int * curId=new int [length];
     cout<<"请输入水军的ID列表"<<endl;
    for(int j=0;j<length;j++)
    {
        cin>>curId[j];
    }
    for(int i=0;i<length;i++)
    {
        if(Idnum[0]==0 && curId[i]!=ID[1] && curId[i]!=ID[2])
        {
            Idnum[0]=1;
            ID[0]=curId[i];
        }
        else if(Idnum[1]==0 && curId[i]!=ID[0] && curId[i]!=ID[2])
        {
            Idnum[1]=1;
            ID[1]=curId[i];
        }
        else if(Idnum[2]==0 && curId[i]!=ID[0] && curId[i]!=ID[1])
        {
            Idnum[2]=1;
            ID[2]=curId[i];
        }
        else if(curId[i]!=ID[0] && curId[i]!=ID[1] && curId[i]!=ID[2])
        {
            Idnum[0]--;
            Idnum[1]--;
            Idnum[2]--;
        }
        else if(curId[i]==ID[0])
        {
            Idnum[0]++;
        }
        else if(curId[i]==ID[1])
        {
            Idnum[1]++;
        }
        else if(curId[i]==ID[2])
        {
            Idnum[2]++;
        }
    }
    cout<<"三个水桶ID为:";
    cout<<ID[0]<<" "<<ID[1]<<" "<<ID[2]<<" "<<endl;
    return 0;
}

4.运行结果。

5.心得体会。

通过题意出发,通过消除的方法实现代码算法。

时间: 2024-10-07 06:13:16

课堂练习-找水王续的相关文章

课堂练习—找水王之小水王

三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数目超过了帖子数目的一半. 要求:如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗? 解决方法: 对所面临的问题进行简化,由于“水王”发帖数目超过了帖子数目的一半,由此可以作为突破口,寻找简单的方法,来解决,可以将发帖的ID看成一位数组,简化 为,在一位数组中,查找一半以上相同的元素

课堂练习—找水王(续)

一.题目 随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID.据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗 二.设计思路 上次是每次删除两个ID,即如果两个ID不同则删除,相同则保留,这次参考原来问题的解法,如果按照数序删除四个完全不同的ID,那么,最后剩下的就是原先发帖比例大于1/4的ID.循环这个过程,把ID总数降低,从而得到问题的答案. 三.源代码 #include<iostream.h> int main() { int ID[10]={1

课堂练习找水王实例

• 题目: 三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数目超过了帖子数目的一半. •如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗?(参考核心代码) •随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID.据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗? 思路:根据老师上课提示的“

软件工程——找水王(续)

一.题目 随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID.据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗 二.设计思路 参考原来问题的解法,如果每次删除4个不同的ID(不管是否超过总数1/4的ID),那么,剩下的ID列表中,原先发帖比例大于1/4的ID所占比例仍然大于1/4.可以通过不断重复这个过程,把ID总数降低,从而得到问题的答案.具体方法:用candidate[3]记录三个候选ID,用count[3]记录它们的累积次数,然后遍历整个ID列表,

找水王(二)

一.题目 一段时间之后,大水王消失了,出现了三个小水王,他们每一个人发帖数超过了总数的1/4. 要求:如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这三个小水王吗? 二.解题思路 将第一次找水王的套路扩展一下,每次删除四个不同的结点,最后就能得到三只水王 三.程序代码 1 #include<iostream> 2 #include<string> 3 using namespace std; 4 int main() 5 { 6 //建立数

找水王 多个水王

package Arraysum; public class FindWaterKing { public static void main(String[] args) { //把id列表放到一个数组里面 int[] idNum = {1,1,1,1,12,3,11,1,1,15,6,6,77,1,1,1,1}; //指向前一个数和后一个数的指针 int previor = 0; int next = 1; //通过while循环来实现两两相消法 while((previor < idNum.

课堂练习——找水王续

题目:随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID.据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗? 一.设计思路 如果按照先排序后查找的话,三个小水王则分别在1/4处,1/2处,3/4处,时间复杂度则为O(nlogn),不满足时间复杂度要求.参考上次找水王题目,每次消除两个不一样ID的帖子,则最后剩下的即是水王.此题可参照此方法,但一次要消除四个不同ID的帖子,消到最后,依旧是他们三个占据总数分别超过1/4.如此做法,虽然满足时间复杂度,但是空

找水王课堂练习

1题目要求: 三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数目超过了帖子数目的一半. 如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗? 2 设计思路: 1首先如果每次删除两个不同的ID,那么,在剩下的ID列表中,“水王”ID出现的次数仍然超过总数的一半. 2重复这个过程,把ID列表中的ID总数降低,最后找到水王. 3源程序代

找水王(续)

一.题目: 1 三人行设计了一个灌水论坛.信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子.坊间风闻该“水王”发帖数 目超过了帖子数目的一半. 2 如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗?(参考核心代码) 3 随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID.据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗? 二.设计思想 给

找水王-课堂作业

程序代码 结果截图 实验总结 因为水王是整个论坛中发帖和回帖数加起来最多的的人,且超过总帖数的一半以上.(这里将发帖数和回帖数记在一起)使用"两两相消"的方法.将帖子的作者id纳入数组,将数组中的一个数记作疑似水王者,并记发帖数t=0.遍历数组,若数组中的数和疑似水王者id相同,使发帖数t加一.如与疑似水王者id不同,使发帖数t减一.当t=0时,将数组中当前与水王疑似者比较的数作为新的疑似水王者.循环结束,当前水王怀疑者就是水王.