码迷,mamicode.com
首页 > 其他好文 > 详细

开放题代码二

时间:2019-02-03 19:44:35      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:ring   return   strcpy   fine   sig   open   std   输出   while   

#include <stdio.h>
#include <string.h>
#define S 50  //假定次数分界线为50 
int main()
{
    FILE * fp=fopen("Request.txt","r");
    struct date{
        char name[10]; 
        int sum=0;  //用户名出现次数 
    }n[20000];
    struct man{
        char name[10];  //黑客用户名 
    }hac[20];
    int i=0,j,k=0,sign;
    while(fscanf(fp,"%s %*s %*s",&n[i].name)!=EOF){
        sign=1;
        for(int z=0;z<k;z++)if(strcmp(hac[z].name,n[i].name)==0){sign=0;i--;break;}//碰到已经记录的黑客名跳过 
        for(j=0;j<i&&sign;j++)  //新读入的(非黑客)是否已经出现过   
            if(strcmp(n[i].name,n[j].name)==0){ //如果已经出现过 
                n[j].sum++;
                if(n[j].sum>=S)strcpy(hac[k].name,n[j].name),k++;  //记录新黑客用户名 
                break;
            }
        if(j==i)n[i].sum++;//如果没有出现过 
        i++; 
    }
    printf("%d\n",k);//输出黑客数目 
    for(int j=0;j<k;j++)
        printf("%s\n",hac[j].name);//输出名字 
    fclose(fp); 
    return 0;
}

开放题代码二

标签:ring   return   strcpy   fine   sig   open   std   输出   while   

原文地址:https://www.cnblogs.com/zlonglongago/p/10350830.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!