C/C++ Qt实现文章小说人物关系分析
短信预约 -IT技能 免费直播动态提醒
一、所需工具软件
1. Visual Stuido
2. C++
二、使用步骤
1.引入库
代码如下(示例):
#include "QtGuiApplication1.h"
#include<qDebug>
#include<QFile>
#include <fstream>
#include<iostream>
using namespace std;
#include <sstream>
#include <unordered_map>
2.创建元素操作函数
代码如下(示例):
//读取人物名称
void QtGuiApplication1::readOnButton()
{
//打开关键词文件
ifstream ifs;
ifs.open("name.txt", ios::in);
if (!ifs.is_open())
{
cout << "打开文件失败" << endl;
return;
}
//一行一行读取到数组中
string buf;
while (getline(ifs, buf))
{
cout << buf << endl;
QString name = QString::buf);
gNameList << name;
}
ifs.close();
ui.textEdit->setPlainText(gNameList);
}
//出现次数
void QtGuiApplication1::timesOnButton()
{
qDebug() << QString::fromLocal8Bit("人名次数统计");
//统计归零
if (gNameList.size() == 0)
{
std::cout << "请倒入人名列表后再试!" << std::endl;
}
gNameCounter.clear();
for (auto name : gNameList)
{
std::string key = name.toLocal8Bit();
gNameCounter[key] = 0;
}
//一行行读入小说
ifstream ifs;
ifs.open("天龙八部.txt", ios::in);
if (!ifs.is_open())
{
cout << "打开文件失败" << endl;
return;
}
//清空统计用的TABLE的数据
gTable.clear();
//统计结果显示到界面
QStringList result;
for (auto name : gNameList)
{
std::string keyword = name.toLocal8Bit();
QString tmp = name + ":" + QString::number(gNameCounter[keyword]);
result << tmp;
std::cout << keyword << " " << gNameCounter[keyword] << std::endl;
}
ui.textEdit_3->setText(result.join("\n"));
}
//篇幅跨度
void QtGuiApplication1::rangeOnButton()
{
ui.textEdit_3->clear();
for (auto name : gNameList)
{
std::string keyword = name.toLocal8Bit();
int firstLineNum = -1;
int lastLineNum = -1;
for (int i = 0; i < gTable.size(); i++)
{
auto& row = gTable.at(i);
//std::cout << "行号:" << i << " ";
int KeyWordCounts = row[keyword];
if (KeyWordCounts > 0)
{
if (firstLineNum == -1)
{
firstLineNum = i;
}
lastLineNum = i;
}
}
ui.textEdit_3->append(QString::number(lastLineNum - firstLineNum));
}
}
//关系最紧密两人
void QtGuiApplication1::relationGoodOnButton()
{
ui.textEdit_3->clear();
qDebug() << "test";
//关系紧密算法,原理每个人名在第几行出现的行数集合和另一个人名行数集合求距离,取最小值为它的精密度
//值越小的那个为此人和另一个人的最精密度,然后同样的方法计算出此人与其它人的精密度,最终取得
//谁和这个人最紧密
std::map < std::string, std::vector<int>> DataContainer;
//正在对比的两个选手
std::string player1, player2;
int theMinDistance = 9999999999999999;
for (auto name : gNameList)
{
std::string keyword = name.toLocal8Bit();
std::vector<int> rowNums;
for (int i = 0; i < gTable.size(); i++)
{
auto& row = gTable.at(i);
//std::cout << "行号:" << i << " ";
int KeyWordCounts = row[keyword];
if (KeyWordCounts > 0)
{
rowNums.push_back(i);
}
}
DataContainer[keyword] = rowNums;
}
ui.textEdit_3->append(QString::number(theMinDistance)+ QStringLiteral("行"));
}
三、运行结果
到此这篇关于C/C++ Qt实现文章小说人物关系分析的文章就介绍到这了,更多相关Qt小说人物关系分析内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341