RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

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

主页

user709676
user709676
Asked: 2025-05-01 04:17:48 +0000 UTC

优化简单代码(String.valueOf)

  • 6

任务如下:

输入输出数据:

数据示例:

我解决了这个问题,但是在我的算法中我使用 String.valueOf 方法将数组的每个元素转换为字符串,这占用了大量的内存。我该如何优化我的代码?

public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    int n = scanner.nextInt();
    int k = scanner.nextInt();
    int[] list = new int[n + 1];
    for (int i = 0; i < n; i++) {
        list[i] = scanner.nextInt();
    }
    System.out.println(findMaxDifference(list,k));
}

public static long findMaxDifference(int[] list, int k) {
    long result = 0;
    for (int i = 0; i < k; i++) {
        list = refactorNum(list);
        result += list[list.length - 1]; // увеличиваю результат по последнему индексу массива
        list[list.length - 1] = 0; // обновляю его
    }
    return result;
}

private static int[] refactorNum(int[] list) {
    int prevIndex = -1;
    int prevValue = -1;
    for (int i = 0; i < list.length-1; i++) {
        String stringNum = String.valueOf(list[i]); // (проблема) создаю n*k объектов String
        for (int j = 0; j < stringNum.length(); j++) {
            if (stringNum.charAt(j) != '9') {
                stringNum = stringNum.replaceFirst(String.valueOf(stringNum.charAt(j)),"9");
                int parsedInt = Integer.parseInt(stringNum);
                if (parsedInt - list[i] > list[list.length-1]) {
                    if (prevIndex != -1) {
                        list[prevIndex] = prevValue;
                    }
                    prevIndex = i;
                    prevValue = list[i];
                    list[list.length-1] = parsedInt - list[i]; // ожидаемый результат
                    list[i] = parsedInt;
                }
                break;
            }
        }
    }
    return list;
}

}

java
  • 1 个回答
  • 22 Views
Arame Barseghyan
Arame Barseghyan
Asked: 2025-05-01 00:47:48 +0000 UTC

请给我一些关于如何改进代码的建议?

  • 5

请给我一些关于如何改进代码的建议?

goto(Math.random() * 600 - 300, Math.random() * 600 - 300);
let s = 0;

for (let index = 0; index < 60; index++) {
  let a = Math.random();
  let b = Math.random();
  if (s === 0) {
    colour(127, 0, 255, 1);
  } else if (s === 1) {
    colour(250, 156, 28, 1);
  } else if (s === 2) {
    colour(0, 120, 255, 1);
  }
  forward(Math.random() * 150);
  if (a > b) {
    left(90);
  } else {
    right(90);
  }
  s = (s + 1) % 3;
}
javascript
  • 1 个回答
  • 29 Views
Mik
Mik
Asked: 2025-04-30 23:47:35 +0000 UTC

C语言、地址运算、指针和malloc

  • 8

各位同事,我实在想不通问题出在哪里。

存在一个问题:

接受int n; - 从控制台输入的序列中的实数个数。将所有数字显示为小数点后两位。例如:输入 - 3 4.123 7.011 5.1// 3 - 数字的数量(<100),其余的是数字本身。

结论 -4.12 7.01 5.10

这是我得到的代码:

#include <stdio.h>
#include <stdlib.h>

main(){
    int n=0,i=0;
    double *pn;

    scanf("%d",&n);                        // Принимаю кол-во чисел в последовательности
    pn=(double *)malloc(n*sizeof(double)); // Присваиваю указатель на первый элемент блока 
                                           //   из n-ячеек памяти размером double 
    while(i<n)                             // Гоняю цикл n-раз
        scanf("%f",pn+i++);                // После присваивания инкрементирую i для 
                                           //   смещения в следующем цикле, по блоку памяти 
                                           //   выделенным malloc
    while(i>0){
        printf("%.2f\n",*(pn + n - i--));  // Вывод чисел n-раз с 2-мя десятичными знаками
    }
    free(pn);                              // Освобождаю память, хотя, она и так 
                                           // освободится после выхода из программы,
                                           // если я правильно понимаю.
}

结果如下:

![结果

如果我使用类型指示器 int *并输入int数字,将格式从 更改为"%f","%d"那么它似乎可以工作:

似乎有效

我不明白——为什么它不适用于实数?

我想了解指针和地址算术,所以我选择了这个解决方案。

c
  • 2 个回答
  • 32 Views
Flowerself
Flowerself
Asked: 2025-04-30 18:31:16 +0000 UTC

我不知道错误是什么,按钮不起作用,机器人没有反应

  • 6
import asyncio
from random import randint
from telegram import Update
from telegram.ext import Application, CommandHandler, MessageHandler, filters, CallbackQueryHandler, ContextTypes
from telegram import InlineKeyboardButton, InlineKeyboardMarkup

choices = ["камень", "ножницы", "бумага"]

scissors = InlineKeyboardButton("Ножницы", callback_data="Ножницы")
rock = InlineKeyboardButton("Камень", callback_data="Камень")
paper = InlineKeyboardButton("Бумага", callback_data="Бумага")

rockboard = InlineKeyboardMarkup([
    [scissors, rock],
    [paper]
])

TOKEN = ''


async def start_cmd(update: Update, context: ContextTypes.DEFAULT_TYPE):
    print(update.effective_user.first_name)
    print("Получена команда /game")
    await update.message.reply_text(f'Привет, 🎮\nДавай сыграем в Камень, Ножницы, Бумага! Выбери свой вариант ниже ⬇️"', reply_markup=rockboard)

async def handle_choice(update: Update, context: ContextTypes.DEFAULT_TYPE):
    bot_choice = randint.choice(["Камень", "Ножницы", "Бумага"])
    result = determine_winner(update.message.text, bot_choice)
    await update.message.reply_text(f"Вы выбрали: {update.message.text} Бот выбрал: {bot_choice} Результат: {result}")

def determine_winner(user, bot):
    if user == bot:
        return "Ничья!"
    elif (user == "камень" and bot == "ножницы") or \
            (user == "ножницы" and bot == "бумага") or \
            (user == "бумага" and bot == "камень"):
        return "Ты выиграл!"
    else:
        return "Я выиграл!"

def main():
    application = Application.builder().token(TOKEN).build()
    application.add_handler(CommandHandler("game", start_cmd))
    print("Бот запущен!")
    application.run_polling()

if __name__ == '__main__':
    main()
python
  • 1 个回答
  • 34 Views
alexkolykhalov
alexkolykhalov
Asked: 2025-04-30 16:52:23 +0000 UTC

异步等待和调度事件

  • 6
button.addEventListener("click", function() {
  const ce = new CustomEvent(
    "board:select",
    { bubbles: false, cancelable: true, detail: {} }
  );

  const isCancelled = !document.querySelector(`#${Board.prefix}`)?.dispatchEvent(ce);

  console.log(isCancelled ? "is cancelled" : "is not cancelled");
}

//I вариант
document.querySelector(`#${Board.prefix}`)?.addEventListener("board:select", function() {
  event.preventDefault();
})

//II вариант
document.querySelector(`#${Board.prefix}`)?.addEventListener("board:select", async function() {
  const data = await fetch("http://localhost:4000/boards"); 
  event.preventDefault();
})

有一个简单的代码,当按下按钮时会发送一个事件。

问题:为什么第一个选项中 isCancelled 为真,而第二个选项中 isCancelled 为假。

我想等到 fetch 执行完毕然后设置 event.preventDefault();或不放。现在在第二个选项中 event.preventDefault();不起作用。

告诉我发生了什么事?

javascript
  • 2 个回答
  • 19 Views
Vyacheslav Arkhipkin
Vyacheslav Arkhipkin
Asked: 2025-04-30 03:44:20 +0000 UTC

供批评的客户端-服务器应用程序架构图

  • 6

有一个客户端服务器应用程序。我制作了这张图。她看上去怎么样?

通过产品的文本属性进行全文搜索。

Redik - 用于计算商品、卖家平均评分值的缓存层

S3——用于存储大文件

在此处输入图片描述

spring
  • 1 个回答
  • 28 Views
Cyrtolat
Cyrtolat
Asked: 2025-04-30 01:27:35 +0000 UTC

在微服务架构中何时何地请求用户名:创建、存储还是检索消息时?

  • 5

我有一个实现消息传递系统的微服务架构。一切安排如下:

  • IdentityService 是一个单独的微服务,用于存储用户全名。
  • MailboxService 是一种管理邮箱和消息的服务。这里存储了消息、发件人和收件人 ID 以及电子邮件地址(电子邮件是邮箱的一部分)。
  • GatewayService 是一个充当服务之间协调器的 API 层。

每条消息都包含一个senderId和recipientId,以及这些用户的名称(senderName,recipientName)。问题在于名称仅存在于 IdentityService 中,而消息是在 MailboxService 中创建和存储的。

我不明白在哪里插入全名更正确,以及存在哪些架构上的妥协。我了解这是微服务的典型痛点,所以我对社区的意见很感兴趣。以下是我正在考虑的选项:

⸻

选项 1:在 GatewayService 中创建消息时获取名称

GatewayService 不创建电子邮件,而是调用 MailboxService。此时,它从 IdentityService 请求名称并将它们与其余数据一起传递给 MailboxService。 MailboxService将senderName、recipientName直接存储在Message中。

优点:

  • MailboxService 对 IdentityService 一无所知。
  • 消息中的数据是自给自足的;客户端不需要上传任何额外的东西。

缺点:

  • 数据重复(名称既存储在身份中,也存储在每条消息中)。
  • 当用户更改其姓名时,旧消息仍保留旧姓名。
  • GatewayService 变得“胖”,从两个服务中提取逻辑。

⸻

选项 2:将所有者姓名存储在邮箱中

创建邮箱时,用户的全名将与用户 ID 一起保存在其中。创建消息时,发件人姓名从邮箱中获取,收件人姓名通过外部调用或从缓存中获取。

优点:

  • 集中化:邮箱了解其所有者的一切信息。
  • MailboxService 可以自行创建消息,无需 GatewayService 的帮助。

缺点:

  • 名称改变时,数据可能会重复并过时。
  • MailboxService 开始存储语义上的身份 - SRP 违规。

⸻

选项 3:根本不存储姓名,在检索消息时替换

MailboxService 仅存储发件人和收件人 ID。当通过 GatewayService 检索消息时,它会收集一堆 ID,并向 IdentityService 发出请求以填写全名。

优点:

  • 清晰的架构:每个服务只知道它应该做什么。
  • 名字总是相关的。

缺点:

  • 提取逻辑的复杂性(需要进行类似连接的查询)。
  • 性能——当消息和用户数量众多时,身份查询可能会成为瓶颈。幸运的是,这并不意味着高负载(封闭的网络,低流量,只有几千个用户)

⸻

问题:

当使用来自另一个服务(如全名)的不涉及业务逻辑但仅需要显示的“次要”数据时,哪种方法在微服务架构中更正确和更容易被接受?

микросервисы
  • 1 个回答
  • 24 Views
Филипп Шувалов
Филипп Шувалов
Asked: 2025-04-29 18:15:51 +0000 UTC

CadQuery python:构建对象的复杂倒角

  • 8

尝试在 CadQuery Python 中对螺栓进行建模:

import cadquery as cq
from math import sqrt, tan, radians

# Параметры модели
head_diameter = 10.0  # Диаметр по вершинам (описанная окружность)
head_height = 5.0     # Высота головки
shaft_diameter = 5.0  # Диаметр стержня
shaft_length = 20.0   # Длина стержня

# Расчетные параметры
R = head_diameter / 2                 # Радиус описанной окружности
r = R * sqrt(3)/2                     # Радиус вписанной окружности
chamfer_size = (R - r) / tan(45)      # Размер фаски для угла 45°

#1. Создаем шестигранную головку
bolt_head = (
    cq.Workplane("XY")
    .polygon(6, 2*R)                  # Создаем шестигранник
    .extrude(head_height)              # Выдавливаем на высоту головки
    .translate((0, 0, -1 * (head_height/2)))
)

bolt_head = bolt_head.edges("Z").chamfer(1)

# 2. Создаем стержень
bolt_shaft = (
    cq.Workplane("XY")
    .circle(shaft_diameter/2)
    .extrude(-shaft_length)
)

# 3. Объединяем компоненты
bolt = bolt_head.union(bolt_shaft)

结果是这样的胡言乱语: 在此处输入图片描述

现在的问题是。如何以 45 度角切割螺栓头的顶角。目标是得到像这样的螺栓头: 在此处输入图片描述

python
  • 2 个回答
  • 49 Views
Лиза Кригер
Лиза Кригер
Asked: 2025-04-29 14:14:48 +0000 UTC

如何编写不重复最大行数的代码

  • 6

电子表格文件每行包含七个自然数。确定表格行中满足以下条件的最小数字的总和:

  • 一行中有两个数字,每个数字重复两次,另外三个数字不同;

  • 最大行数不重复。

在你的回答中,只写下数字。

f = open("9")
cnt = 0
for s in f:
    a = list(map(int, s.split()))
    povt = [x for x in a if a.count(x) > 1]
    ne_povt = [x for x in a if a.count(x) == 1]
    if (len(ne_povt) == 3 and len(set(povt)) == 2) and max(ne_povt) == 1:
        cnt += 1
print(cnt)
python
  • 2 个回答
  • 103 Views
Nikolay Stuff
Nikolay Stuff
Asked: 2025-04-29 00:33:15 +0000 UTC

使用 Zenject 在 Unity 中实现装饰器

  • 6

有一个界面:

public interface IUpdatable 
{
    public void Awake();
    public void Start();
    public void Update();
    public void FixedUpdate();
    public void LateUpdate();
}

该接口旨在从不继承自的类中提取 Unity 方法MonoBehaviour。我有一个PlayerController实现该接口的类。

这是装饰器本身。我试图使用接口将所有调用集中在一个地方,但是当我运行它时,它至少List<IUpdatable> updatable有一个后继者。Count = 0;IUpdatable

public class UpdatableDecorator : MonoBehaviour
{
    private List<IUpdatable> _updatables  = new();
    
    [Inject]
    public void Construct(List<IUpdatable> updatable)
    {
        _updatables.AddRange(updatable);
        Debug.Log(_updatables.Count);
    }
    private void Awake()
    {

        foreach (var awake in _updatables)
        {
            awake.Awake();
        }
    }
    void Start()
    {
        foreach (var start in _updatables)
        {
            start.Start();
        }
    }


    void Update()
    {
        foreach (var update in _updatables)
        {
            update.Update();
        }
    }
    private void FixedUpdate()
    {
        foreach (var fixedUpdate in _updatables)
        {
            fixedUpdate.FixedUpdate();
        }

    }

    private void LateUpdate()
    {
        foreach (var lateUpdate in _updatables)
        {
            lateUpdate.LateUpdate();
        }
    }
}

绑定如下所示SceneInstaller:

private void BindDicorator()

{
      Container.Bind<List<IUpdatable>>().AsSingle();
      Container.BindInterfacesAndSelfTo<UpdatableDecorator>().FromComponentInHierarchy().AsSingle();
}

我不知道我做错了什么。我将非常感激您的指导。

c#
  • 1 个回答
  • 64 Views
alexWithoutBeard
alexWithoutBeard
Asked: 2025-04-28 20:34:32 +0000 UTC

使用函数,从有效的 html 代码中获取所有 src 图像

  • 5

有必要实现 getSrc(),它接收一段有效的(即没有错误编写的)html 代码作为输入,该代码可以包含多个图像。获取图像的src属性的值。该属性可以用单引号或双引号引起来,例如,src="test.png", src='test.png'。

src 返回字符串

我得到以下信息:

function getSrc(html) {
  let str = html.toLowerCase();
  let pos = 0;
  let res = ''
  let k = str.indexOf('<img ');
  let src = str.indexOf("src=", k);
  while (str.indexOf('<img ', pos + 1) != -1) {
    let open =
      str.indexOf('"', src) != -1 ?
      str.indexOf('"', src) :
      str.indexOf("'", src);
    let close =
      str.indexOf('"', open + 1) != -1 ?
      str.indexOf('"', open + 1) :
      str.indexOf("'", open + 1);
    pos += close;
    res += str.slice(open + 1, close) + ' ';

  }

  return res

}

getSrc('<table><tr><td><img width="200" src="google.jpg"></td></tr><tr><td><img width="200" src='
  chrome.jpg '></td></tr><tr><td><img width="200" src="safari.jpg"></td></tr><tr><td><img width="200" src="edge.jpg"></td></tr></table>')

它应该输出:google.jpg chrome.jpg safari.jpg edge.jpg。我得到:google.jpg google.jpg google.jpg google.jpg

我明白错误在于我将相同的 src 传递给 while,但如何修复它......有趣的是我在 React 中编写组件,但我被这个困住了)

javascript
  • 2 个回答
  • 48 Views
geo
geo
Asked: 2025-04-28 18:28:02 +0000 UTC

自定义异常集存储在哪里?

  • 5

为了在类中使用,我需要一组异常,我从 Exceptions 继承并将该组异常存储在模块中(在标题中),我将其构造如下:

class BaseUserError(Exception):
    pass

class AccountError(BaseUserError):
    pass

class DebitError(AccountError):
    pass

class CreitError(AccountError):
    pass

希望将它们移动到用作子类的类中(例如,Account 类、Client 类等等)。这样看来似乎更正确。谁存储在哪里以及为什么存储?

python
  • 1 个回答
  • 35 Views

Sidebar

Stats

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

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

    • 3 个回答
  • Marko Smith

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

    • 5 个回答
  • Marko Smith

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

    • 2 个回答
  • Marko Smith

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

    • 2 个回答
  • Marko Smith

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

    • 2 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +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