RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / user-475402

Dedalus Morffino's questions

Martin Hope
Dedalus Morffino
Asked: 2022-08-23 03:44:58 +0000 UTC

请帮助解决EOlimp问题[关闭]

  • 0
关闭 这个问题是题外话。目前不接受回复。

寻求调试帮助的问题(“为什么这段代码不起作用? ”)应该包括期望的行为、具体的问题或错误,以及在问题中重现它的最少代码。没有明确描述问题的问题对其他访问者毫无用处。请参阅如何创建一个最小的、独立的和可重现的示例。

3 个月前关闭。

改进问题

所以,这就是问题本身:https ://www.eolymp.com/ru/problems/3922

这是我在伪代码中的解决方案:

function solve(input: string) -> string {
    let lines = input.split("\n");
    let n = int(lines[0]);
    
    let l = lines.length();
    for(let j = 0; j < lines.length(); j += 1) {
        if(lines[j].length() == 0) { l -= 1; }   
    }
    
    let mes: int[] = [];
    let pos: int[] = [];
    let i = 1;
    while(i < l) {
        mes.push(int(lines[i]));
        pos.push(i);
        if(int(lines[i]) == 0) { i += 3;}
        else { i += 2;}
    }
    
    let rel: int[] = [];
    for(let j = 0; j < mes.length(); j += 1) {
        rel.push(0);
    }
    
    for(let j = 0; j < mes.length(); j += 1) {
        if(mes[j] != 0) {
            if(mes[mes[j] - 1] == 0) {
                rel[mes[j] - 1] += 1;
            }
        }
    }
    
    let index = 0;
    for(let j = 0; j < rel.length(); j += 1) {
        if(rel[j] > rel[index]) {
            index = j;
        }
    }
    
    
    return lines[pos[index] + 1];
}

这里的input是一串输入数据(自然是带有光标翻译字符\n),返回时显示答案。它适用于我的样品,但发送时我会抓住 WA。也许我在某个地方遗漏了一些东西。请告诉我在哪里?)

алгоритм олимпиада
  • 1 个回答
  • 38 Views
Martin Hope
Dedalus Morffino
Asked: 2022-08-06 21:41:38 +0000 UTC

帮助完成C++问题的解决

  • 1

条件: https ://www.eolymp.com/ru/problems/7310

我的决定:

#include <iostream>
#include <cmath>

using namespace std;          /*  eolymp - 7310*/

int main()
{
    int bs, n;
    cin >> n >> bs;

    int ans = n * (n + 1) / 2;

    if ((-1. + sqrt(8. * bs + 1.)) / 2. == int((-1. + sqrt(8. * bs + 1.)) / 2.))
        ans -= 1;

    cout << ans;
    return 0;
}

我的想法:如果 badStep(bs) 不等于差为 1 的算术级数的任何成员,那么一切都很好,我们可以正常进行所有步骤,即我们只需显示这样一个元素的总和进展。如果不是,我们干脆不迈出第一步,然后我们肯定不打 bs 进一步的步骤,答案将是相同的数量减 1。

(-1. + sqrt(8. * bs + 1.)) / 2.

这是从二次方程 ni(ni + 1) = bs 的解中得出的结果,其中 ni 是级数中某个成员的数量。嗯,即 我检查元素的总和是否= bs,元素的数量是整数,结果我们进入bs,我们需要减去1(不要打)

问题:(https://www.eolymp.com/ru/submissions/11153820)由于某种原因,一个测试没有通过,也许是某种异常,但不管我怎么想,我就是想不通在哪里。请帮帮我 )

алгоритм c++
  • 1 个回答
  • 52 Views
Martin Hope
Dedalus Morffino
Asked: 2022-05-15 22:41:21 +0000 UTC

C++程序帮助

  • -3

所以,我刚开始在 C++ 中艰难地前进,所以我决定制作一个简单的程序:发出问题并为它们评分。本质我就不深究了,但是程序的思路是这样的:在包含的文件中,我创建并初始化一个二维向量,其中每个元素是一个问题的一行,我也存储主题的数量。现在例如将有 1 个主题,但这并不重要。重要的是,当我尝试这样做时,会遇到一连串错误,问题是:我做错了什么,我怎样才能做得更好?编码:

#ifndef QPACK1_H
#define QPACK1_H

int theme_amount = 1;
std::vector<std::vector<std::string> > questions(theme_amount + 1, std::vector<std::string>(6, " "));


questions[1][0] = "Вы попали на тему: Name of the theme\n" ;    // сначала номер темы, потом номер вопроса(по 5), 0 вопрос - название темы.

questions[1][1] = "Question 1";
questions[1][2] = "Question 2";
questions[1][3] = "Question 3";
questions[1][4] = "Question 4";
questions[1][5] = "Question 5";


#endif

错误列表:

1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(8,1): error C2466: невозможно выделить память для массива постоянного нулевого размера
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(8,17): error C2087: questions: отсутствует индекс
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(8,19): error C4430: отсутствует спецификатор типа - предполагается int. Примечание. C++ не поддерживает int по умолчанию
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(10,19): error C4430: отсутствует спецификатор типа - предполагается int. Примечание. C++ не поддерживает int по умолчанию
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(10,1): error C2040: questions: "int [1][1]" отличается по уровням косвенного обращения от "std::vector<std::vector<std::string,std::allocator<std::string>>,std::allocator<std::vector<std::string,std::allocator<std::string>>>>"
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(11,19): error C4430: отсутствует спецификатор типа - предполагается int. Примечание. C++ не поддерживает int по умолчанию
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(11,1): error C2040: questions: "int [1][2]" отличается по уровням косвенного обращения от "std::vector<std::vector<std::string,std::allocator<std::string>>,std::allocator<std::vector<std::string,std::allocator<std::string>>>>"
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(12,19): error C4430: отсутствует спецификатор типа - предполагается int. Примечание. C++ не поддерживает int по умолчанию
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(12,1): error C2040: questions: "int [1][3]" отличается по уровням косвенного обращения от "std::vector<std::vector<std::string,std::allocator<std::string>>,std::allocator<std::vector<std::string,std::allocator<std::string>>>>"
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(13,19): error C4430: отсутствует спецификатор типа - предполагается int. Примечание. C++ не поддерживает int по умолчанию
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(13,1): error C2040: questions: "int [1][4]" отличается по уровням косвенного обращения от "std::vector<std::vector<std::string,std::allocator<std::string>>,std::allocator<std::vector<std::string,std::allocator<std::string>>>>"
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(14,19): error C4430: отсутствует спецификатор типа - предполагается int. Примечание. C++ не поддерживает int по умолчанию
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\qpack1.h(14,1): error C2040: questions: "int [1][5]" отличается по уровням косвенного обращения от "std::vector<std::vector<std::string,std::allocator<std::string>>,std::allocator<std::vector<std::string,std::allocator<std::string>>>>"
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\CHGK_game.cpp(44,52): error C2088: [: недопустимо для class
1>C:\Users\User\source\repos\ConsoleApplication2\ConsoleApplication2\CHGK_game.cpp(46,48): error C2088: [: недопустимо для class

主程序代码:

#include <vector>
#include <iostream>
#include <string>

#include "qpack1.h" //список вопросов



struct players
{
    std::vector<std::string> name;
    std::vector<int> score;
};




int main()
{   
    int pl_amount, qst_number = 0;
    players plist;
    std::string input;
    
    std::cout << "Enter number of players(less then 10): ";
    std::cin >> pl_amount;
    
    plist.name.resize(pl_amount);
    plist.score.resize(pl_amount);
    plist.score.assign(plist.score.size(), 0);

    std::cout << "Enter players names: \n";
    for (int i = 0; i < pl_amount; i++)
        std::cin >> plist.name[i];

    std::cout << "Tips: enter stop to left the game. \nUse + or - and number of player to give(take out) points to his score.\n";
    for (int theme_number = 1; theme_number <= theme_amount; theme_number++)
    {

        while (qst_number <= 4)
        {
            qst_number++;
            if (qst_number == 1)
                std::cout << questions[theme_number][0] << "\n";

            std::cout << questions[theme_number][qst_number] << "\n";

            TryAgain:
            getline(std::cin, input);

            if (input == "stop")
                goto Results;

            if(input.size() != 2 || !(input[1] > '0' && input[1] <= '9'))
            {
                std::cout << "Incorrect input.\n";
                goto TryAgain;
            }

            if(input[1] - '0' > pl_amount || input[1] - '0' <= 0)
            {
                std::cout << "Incorrect input(Player was not found).\n";
                goto TryAgain;
            }

            if (input[0] == '+')
            {
                plist.score[input[1] - '0' - 1] += qst_number * 10;
                std::cout << plist.name[input[1] - '0' - 1] << " Gets + " << qst_number * 10 << " points!\n";
            }
            else
                if (input[0] == '-')
                {
                    plist.score[input[1] - '0' - 1] -= qst_number * 10;
                    std::cout << plist.name[input[1] - '0' - 1] << " Gets - " << qst_number * 10 << " points!\n";
                }
                else { std::cout << "Please start input with + or -.\n";goto TryAgain; }
                     


        }
        qst_number = 0;
    }

    Results:
    std::cout << "The final score is: \n";

    for (int j = 0; j < pl_amount; j++)
        std::cout << plist.name[j] << " : " << plist.score[j] << " points. \n";
}

还有一个问题:第一次显示主题和问题时,紧接着显示输入错误,尽管没有输入任何内容。(通过注释掉这部分来检查:)

questions[1][0] = "您已进入主题:主题名称\n" ; // 首先是主题编号,然后是问题编号(按 5),0 question - 主题名称。

questions[1][1] = "Question 1";
questions[1][2] = "Question 2";
questions[1][3] = "Question 3";
questions[1][4] = "Question 4";
questions[1][5] = "Question 5";

一般来说,如何解决?)

c++
  • 1 个回答
  • 10 Views

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5