86.八千万qq密码按相似度排序并统计密码出现次数,生成密码库
- 存储qq的文件地址以及按照密码相似度排序的文件地址
//存储qq的文件的地址
char path[] = "QQ.txt";
//按照密码相似度排序的文件地址
char pathsortbypass[] = "QQpasswordsort.txt"; - 标识qq一共有多少行
//文件一共有多少行
#define N 84331446 - 创建结构体存储密码,并把文件载入内存
//密码信息
struct info
{
char str[];
}; //指向所有结构体的指针
struct info *pall = NULL;//初始化
void init()
{
//记录时间
time_t start, end;
time(&start); pall = calloc(N, sizeof(struct info));//分配内存
if (pall==NULL)
{
puts("calloc fail");
return;
}
//打开文件
FILE *pf = fopen(path, "r"); //依次读取
for (int i = ; i <N; i++)
{
char str[] = { };
fgets(str, , pf);
char *pfind = strstr(str, "----");
//每行格式123----qweqe
if (pfind !=NULL)
{
int length = strlen(pfind + );
//刷掉非法密码
if (length<)
{
//拷贝字符串
strcpy(pall[i].str, pfind + );
}
}
}
//关闭文件
fclose(pf);
time(&end);
printf("文件读取话费%f秒\n", difftime(end, start));
} - 按照相似度快速排序
//快速排序比较函数,比较两个结构体
int com(void *p1, void *p2)
{
struct info *pinfo1 = p1;
struct info *pinfo2= p2;
return strcmp(pinfo1->str, pinfo2->str);//排序的函数
} //排序
void sort()
{
//记录时间
time_t start, end;
time(&start); //快速排序
qsort(pall, N, sizeof(struct info), com); time(&end);
printf("排序话费%f秒\n", difftime(end, start));
} - 写入文件
//写入文件
void writetofile()
{
//存储时间
time_t start, end;
//开始时间
time(&start);
//以写的方式打开文件
FILE *pf = fopen(pathsortbypass, "w");
//判断每一个
for (int i = ; i < N; i++)
{
//格式 5----pass
char allstr[] = { };
//存储密码
char istr[] = { };
strcpy(istr, pall[i].str);//拷贝备份 int j = ;//出现一次
//循环直到最后一个不相等
while (strcmp(pall[i].str,pall[i+].str)==)
{
i++;//循环前进
j++;//计数
}
//合成字符串写入
sprintf(allstr, "%d----%s", j, istr);
//写入到文件
fputs(allstr, pf);
} //关闭文件
fclose(pf); //结束
time(&end); printf("排序花费%f秒\n", difftime(end, start));
} - 获取文件有多少行
//获取文件有多少行
int getN(char *path)
{
int i = ;
FILE *pf = fopen(path, "r");
if (pf==NULL)
{
return -;
}
else
{
while (!feof(pf))
{
char str[] = { };
fgets(str, , pf);
i++;
} fclose(pf);
return i;
}
} - 主函数
//主函数
void main()
{
//初始化载入到内存
init();
//密码相似度排序
sort();
//写入文件
writetofile();
system("pause");
}
完整代码
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<time.h> //存储qq的文件的地址
char path[] = "QQ.txt";
//按照密码相似度排序的文件地址
char pathsortbypass[] = "QQpasswordsort.txt";
//文件一共有多少行
#define N 84331446 //密码信息
struct info
{
char str[];
}; //指向所有结构体的指针
struct info *pall = NULL; //写入文件
void writetofile()
{
//存储时间
time_t start, end;
//开始时间
time(&start);
//以写的方式打开文件
FILE *pf = fopen(pathsortbypass, "w");
//判断每一个
for (int i = ; i < N; i++)
{
//格式 5----pass
char allstr[] = { };
//存储密码
char istr[] = { };
strcpy(istr, pall[i].str);//拷贝备份 int j = ;//出现一次
//循环直到最后一个不相等
while (strcmp(pall[i].str,pall[i+].str)==)
{
i++;//循环前进
j++;//计数
}
//合成字符串写入
sprintf(allstr, "%d----%s", j, istr);
//写入到文件
fputs(allstr, pf);
} //关闭文件
fclose(pf); //结束
time(&end); printf("排序花费%f秒\n", difftime(end, start));
} //快速排序比较函数,比较两个结构体
int com(void *p1, void *p2)
{
struct info *pinfo1 = p1;
struct info *pinfo2= p2;
return strcmp(pinfo1->str, pinfo2->str);//排序的函数
} //排序
void sort()
{
//记录时间
time_t start, end;
time(&start); //快速排序
qsort(pall, N, sizeof(struct info), com); time(&end);
printf("排序话费%f秒\n", difftime(end, start));
} //初始化
void init()
{
//记录时间
time_t start, end;
time(&start); pall = calloc(N, sizeof(struct info));//分配内存
if (pall==NULL)
{
puts("calloc fail");
return;
}
//打开文件
FILE *pf = fopen(path, "r"); //依次读取
for (int i = ; i <N; i++)
{
char str[] = { };
fgets(str, , pf);
char *pfind = strstr(str, "----");
//每行格式123----qweqe
if (pfind !=NULL)
{
int length = strlen(pfind + );
//刷掉非法密码
if (length<)
{
//拷贝字符串
strcpy(pall[i].str, pfind + );
}
}
}
//关闭文件
fclose(pf);
time(&end);
printf("文件读取话费%f秒\n", difftime(end, start));
} //获取文件有多少行
int getN(char *path)
{
int i = ;
FILE *pf = fopen(path, "r");
if (pf==NULL)
{
return -;
}
else
{
while (!feof(pf))
{
char str[] = { };
fgets(str, , pf);
i++;
} fclose(pf);
return i;
}
} //主函数
void main()
{
//初始化载入到内存
init();
//密码相似度排序
sort();
//写入文件
writetofile();
system("pause");
}
86.八千万qq密码按相似度排序并统计密码出现次数,生成密码库的更多相关文章
- 72.挖掘CSDN密码到链表并统计密码出现次数生成密码库
list.h #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include & ...
- Linux是对用户的密码的复杂度要求设置【转】
那么Linux是如何实现对用户的密码的复杂度的检查的呢?其实系统对密码的控制是有两部分组成: 1 cracklib 2 /etc/login.defs pam_cracklib.so 才是控制密码复杂 ...
- Linux下随机生成密码的命令总结
有时候经常为如何设置一个安全.符合密码复杂度的密码而绞尽脑汁,说实话,这实在是一个体力活而且浪费时间,更重要的是设置密码的时候经常纠结.终于有一天实在忍不住了,于是学习.整理了一下如何使用Linux下 ...
- five86-1 (OpenNetadmin RCE+cp命令提权+crunch生成密码字典)
Vulnhub-Five86-1 实验环境 kali攻击机ip:192.168.56.116 Five86-1靶机ip:192.168.56.121 知识点及工具 nmap扫描 john爆破 Open ...
- 忘记常访问网站密码怎么办?教你如何查看浏览器已保存的密码,如何简单查看Chome浏览器保存的密码?
利用场景: 同事或朋友外出有事,电脑未锁屏离开座位.可以利用这一间隙,查看Ta在Chrome浏览器上保存的账号密码 查看逻辑: 当我们要查看Chrome浏览器上保存的密码时,点击显示,会弹出一个对话框 ...
- 混合使用 ForkJoin, Akka, Future 实现一千万个不重复整数的排序
定位 本文适合于想要了解新语言 Scala 以及异步并发编程框架 Akka, Future 的筒鞋. 读完本文后,将了解如何使用 ForkJoin 框架.如何使用 Akka 构建并发程序.如何使用 ...
- MySQL忘记了密码登录不进去,用命令符修改新的密码重新登录的方法
MySQL忘记了密码登录不进去,用命令符修改新的密码重新登录的方法: 1.备份my.ini 2.在my.ini字段里 [mysqld] #socket=mysql skip-grant-tables ...
- 利用itertools生成密码字典,多线程撞库破解rar压缩文件密码
脚本功能: 利用itertools生成密码字典(迭代器形式) 多线程并发从密码字典中取出密码进行验证 验证成功后把密码写入文件中保存 #!/usr/bin/env python # -*- codin ...
- 混合使用ForkJoin+Actor+Future实现一千万个不重复整数的排序(Scala示例)
目标 实现一千万个不重复整数的排序,可以一次性加载到 2G 的内存里. 本文适合于想要了解新语言 Scala 并发异步编程框架 Akka, Future 的筒鞋. 读完本文后,将了解如何综 ...
随机推荐
- ES6第一节:开发环境的搭建
前言:由于目前浏览器对ES6的支持度不高,需要借助babel将编写好的ES6代码转换成ES5,浏览器才能解析. 需要在NodeJS环境下运行 一. 建立结构:两个文件夹和一个html文件,分别是src ...
- JavaScript笔记(4)
接上一篇笔记 -----> 打印: 打印: 打印: 一.break 和 continue 的区别 1.break 1.break语句可用于跳出循 ...
- <QT障碍之路>QApplication:No such file or directory
原因:QT5将很多部件都移动了QT widgets模块中. 解决方法: 在.pro文件中添加 greaterThan(QT_MAJOR_VERSION, ): QT += widgets
- JAVA文件写入FileWriter
JAVA文件写入FileWriter 导包import java.io.FileWriter创建构造方法public FileWrite(String filename),参数是文件的路径及文件名(默 ...
- 洛谷——P1518 两只塔姆沃斯牛 The Tamworth Two
https://www.luogu.org/problem/show?pid=1518 题目背景 题目描述 两只牛逃跑到了森林里.农夫John开始用他的专家技术追捕这两头牛.你的任务是模拟他们的行为( ...
- 【php学习笔记】ticks篇
1. 什么是ticks 我们来看一下手冊上面对ticks的解释: A tick is an event that occurs for every N low-level statements exe ...
- python-openpyxl安装
今天在安装openpyxl的时候,一直提示错误,后来才发现仅仅安装它还不够,还需要其他两个库的支持1.安装jdcal2.安装et_xmlfile这两个库安装的方法,都是直接在命令行下面,进入库文件se ...
- PHP的模板引擎smarty原理是什么(整理)
PHP的模板引擎smarty原理是什么(整理) 一.总结 一句话总结:其实所有的模板引擎的工作原理是差不多的,无非就是在php程序里面用正则匹配将模板里面的标签替换为php代码从而将两者混合为一个ph ...
- 2.Brackets安装及常用插件安装
转自:https://blog.csdn.net/autumn20080101/article/details/53171326 Brackets 是一个免费.开源且跨平台的 HTML/CSS/Jav ...
- 利用日志文件恢复MYSQL数据库
利用日志文件恢复MYSQL数据库 650) this.width=650;" onclick='window.open("http://blog.51cto.com/viewpic ...