返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C/C++ Qt实现文章小说人物关系分析
  • 496
分享到

C/C++ Qt实现文章小说人物关系分析

Qt小说人物关系分析Qt人物关系分析Qt关系分析 2023-01-09 18:01:31 496人浏览 泡泡鱼
摘要

目录一、所需工具软件二、使用步骤1.引入库2.创建元素操作函数三、运行结果一、所需工具软件 1. Visual Stuido 2. c++ 二、使用步骤 1.引入库 代码如下(示例)

一、所需工具软件

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小说人物关系分析内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C/C++ Qt实现文章小说人物关系分析

本文链接: https://lsjlt.com/news/177217.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作