72.挖掘CSDN密码到链表并统计密码出现次数生成密码库
- list.h
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h> //创建密码结点
typedef struct passinfo
{
//密码
char password[];
//出现次数
int ci;
//下一个节点
struct passinfo *pNext;
}INFO, *PINFO; //头部插入
PINFO addback(PINFO phead, char password[]);
//按照次数排序
PINFO sortbyci(PINFO phead);
//按照密码排序
PINFO sortbypass(PINFO phead);
//显示数据
PINFO show(PINFO phead);
//判断存在与否
int isin(PINFO phead, char password[]);
//写入到文件
void writetofile(PINFO phead, char path[]); - list.c
#include "list.h" //头部插入
PINFO addback(PINFO phead, char password[])
{
//开辟内存
PINFO pnew = calloc(, sizeof(INFO));
//拷贝密码
strcpy(pnew->password, password);
//初始化
pnew->ci = ;
pnew->pNext = NULL;
//如果头结点为空直接插入
if (phead ==NULL)
{
phead = pnew;
}
//否则头部插入
else
{
pnew->pNext = phead;
phead = pnew;
}
return phead;
} //按照密码次数排序
PINFO sortbyci(PINFO phead)
{
//冒泡排序法,一共冒泡这么多次
for (PINFO p1 = phead; p1 != NULL;p1=p1->pNext)
{
for (PINFO p2 = phead; p2 != NULL; p2 = p2->pNext)
{
if (p2->pNext!=NULL)
{
//如果次数小则进行交换
if (p2->ci < p2->pNext->ci)
{
//交换数据
int citemp = p2->ci;
p2->ci = p2->pNext->ci;
p2->pNext->ci = citemp; char passtemp[];
strcpy(passtemp, p2->password);
strcpy(p2->password, p2->pNext->password);
strcpy(p2->pNext->password, passtemp);
}
}
}
}
} //按照密码排序
PINFO sortbypass(PINFO phead)
{
//冒泡排序
for (PINFO p1 = phead; p1 != NULL; p1 = p1->pNext)
{
for (PINFO p2 = phead; p2 != NULL; p2 = p2->pNext)
{
if (p2->pNext != NULL)
{
if (strcmp(p2->password, p2->pNext->password) < )
{
//交换数据
int citemp = p2->ci;
p2->ci = p2->pNext->ci;
p2->pNext->ci = citemp; char passtemp[];
strcpy(passtemp, p2->password);
strcpy(p2->password, p2->pNext->password);
strcpy(p2->pNext->password, passtemp); }
}
}
}
} //显示数据
PINFO show(PINFO phead)
{
if (phead==NULL)
{
return;
}
else
{
printf("%s,%d\n", phead->password, phead->ci);
show(phead->pNext);
}
return phead;
} //判断密码是否存在
int isin(PINFO phead, char password[])
{
PINFO p = phead;
while (p!=NULL)
{
if (strcmp(p->password,password)==)
{
p->ci += ;
return ;
}
p = p->pNext;
} return ;//不在链表内部
} //写入到文件
void writetofile(PINFO phead, char path[])
{
FILE *pf = fopen(path, "w");
PINFO p = phead;
while (p != NULL)
{
//格式化打印到文件
fprintf(pf, "%s %d\n", p->password, p->ci);
p = p->pNext;
}
fclose(pf);
} - main.c
#include "list.h"
#include <Windows.h>
PINFO phead = NULL; //是否满足格式要求 账号 # 密码 # 邮箱
int isoktosscanf(char *str)
{
//判断是否存在#
char *p = strstr(str, "#");
if (p!=NULL)
{
//继续判断是否存在第二个#
if (strstr(p+,"#")!=NULL)
{
return ;
}
else
{
return ;
}
}
else
{
return ;
}
} //消除空格
void eatspace(char *str)
{
//当前位置
int i = ;
//游标
int j = ;
//双指针错位
while ((str[i]=str[j++])!='\0')
{
if (str[i]!=' ')
{
i++;
}
}
} //文件载入
void fileload()
{
//打开文件
FILE *pf = fopen("csdn.txt", "r"); //如果没有到文件末尾
while (!feof(pf))
{
char str[] = { };
char password[] = { };
//从文件中获取一行
fgets(str, , pf);
//找到第一个#的位置
char*p1 = strstr(str, "#");
//找到第二个#的位置
char*p2 = strstr(p1+, "#");
//分别设置成'\0'
*p1 = '\0';
*p2 = '\0';
//拷贝字符串
strcpy(password, p1 + );
//消除空格
eatspace(password);
//判断是否在链表中
if (isin(phead, password) == )
{
//添加到头结点
phead = addback(phead, password);
}
}
fclose(pf); //按密码次数排序
sortbyci(phead);
//写入到文件
writetofile(phead, "C:\\ci.txt");
//按照密码相似度排序
sortbypass(phead);
//写入到文件
writetofile(phead, "C:\\pass.txt");
} //main函数
void main4()
{
fileload();
system("pause");
}
72.挖掘CSDN密码到链表并统计密码出现次数生成密码库的更多相关文章
- 86.八千万qq密码按相似度排序并统计密码出现次数,生成密码库
存储qq的文件地址以及按照密码相似度排序的文件地址 //存储qq的文件的地址 ] = "QQ.txt"; //按照密码相似度排序的文件地址 ] = "QQpassword ...
- 如何破解密码的哈希值,破解双MD5密码值
这是关于我如何破解密码的哈希值1亿2200万* John the Ripper和oclHashcat-plus故事. 这是几个月前,当我看到一条推特:从korelogic约含共1亿4600万个密码的密 ...
- 扫二维码下载apk并统计被扫描次数(及微信屏蔽下载解决方案)
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/5395715.html 需求:想让用户扫描一个二维码就能下载APP,并统计被扫描次数. 两种实现方法: 1.一 ...
- python统计元素重复次数
python统计元素重复次数 # !/usr/bin/python3.4 # -*- coding: utf-8 -*- from collections import Counter arr = [ ...
- 忘记常访问网站密码怎么办?教你如何查看浏览器已保存的密码,如何简单查看Chome浏览器保存的密码?
利用场景: 同事或朋友外出有事,电脑未锁屏离开座位.可以利用这一间隙,查看Ta在Chrome浏览器上保存的账号密码 查看逻辑: 当我们要查看Chrome浏览器上保存的密码时,点击显示,会弹出一个对话框 ...
- javascript 写一段代码,判断一个字符串中出现次数最多的字符串,并统计出现的次数
javascript 写一段代码,判断一个字符串中出现次数最多的字符串,并统计出现的次数 function test(){ var bt = document.getElementById(" ...
- Linux下随机生成密码的命令总结
有时候经常为如何设置一个安全.符合密码复杂度的密码而绞尽脑汁,说实话,这实在是一个体力活而且浪费时间,更重要的是设置密码的时候经常纠结.终于有一天实在忍不住了,于是学习.整理了一下如何使用Linux下 ...
- hash数组快速查找一个字符串中出现最多的字符,并统计出现的次数
如何快速查找一个字符串中出现最多的字符,并统计出现的次数? 可以使用hash数组,也就是关联数组实现快速查找功能. function seek(str) { var hash = []; var ma ...
- python之pygal:掷两个不同的骰子并统计大小出现次数
代码示例: # 掷两个不同的骰子并统计大小出现次数 import pygal from die_class import Die die = Die(6) # 实例化一个六面的骰子对象 die_10 ...
随机推荐
- ArcGIS api for javascript——渲染-使用分级渲染
描述 本例使用一个分级渲染通过人口密度用符号表示Kansas.代码明确地增加类并为每一个定义颜色.使用ClassBreaksRenderer.addBreak()方法定义类,参数是在类中包含的最大值和 ...
- 多校-HDU 5351 MZL's Border 数学规律
f[1] = 'b', f[2] = 'a', f[i] = f[i - 1] + f[i - 2] 斐波那契数列的字符串,给你n和m,前m位中,最长的前缀等于后缀的长度是多少.1≤n≤1000, 1 ...
- Ftp的上传和下载
百度知道的那个在“ 绑定和SSL设置”模块,选择的是允许 如果一直找不到网页的话,就是这里错了:反正就是牵扯到一堆防火墙的设置(最后我也没搞成) 选择成无就OK了:一切迎刃而解............ ...
- Asp.Net碎知识
在aspx页面 获取值: UserModel user=new UserModel();实例化 user.Address=context["txtAddress"]; 如果前台不需 ...
- 线程框架Executor的用法举例
java5线程框架Executor的用法举例 Executor 是 java5 下的一个多任务并发执行框架(Doug Lea),可以建立一个类似数据库连接池的线程池来执行任务.这个框架主要由三个接口和 ...
- vue的在子组件在使用iview库发现的问题
正常调用没有问题 当写到子组件的时候 这样调用就出问题了 以下是写到子组件出的问题 解决方法 改成了两行写就不会报错了
- python jieba分词工具
源码地址:https://github.com/fxsjy/jieba 演示地址:http://jiebademo.ap01.aws.af.cm/ 特点 1,支持三种分词模式: a,精确模式,试图将句 ...
- [Python] Slicing Lists
In addition to accessing individual elements from a list we can use Python's slicing notation to acc ...
- spring 使用c3po连接池
1 数据源:能够简单理解为数据的来源. 2 连接池:是缓存一定数量的数据库连接,当程序须要数据库连接的时候,直接在连接池中获取空暇的连接,使用完再放回连接池中,此连接又变成空暇状态,等待下一次连接. ...
- strongSwan IKEv2服务器配置
strongSwan IKEv2服务器配置 资料来源 https://www.cl.cam.ac.uk/~mas90/resources/strongswan/ 经过大量的反复试验,我配置了一个str ...