【备战秋招】每日一题:4月1日美团春招(二批)第二题:题面+题目思路 + C++/python/js/Go/java带注释

news2024/12/26 0:29:25

2023大厂笔试模拟练习网站(含题解)

www.codefun2000.com
最近我们一直在将收集到的各种大厂笔试的解题思路还原成题目并制作数据,挂载到我们的OJ上,供大家学习交流,体会笔试难度。现已录入200+道互联网大厂模拟练习题,还在极速更新中。欢迎关注公众号“塔子哥学算法”获取最新消息。
在这里插入图片描述
提交链接:

https://codefun2000.com/p/P1138

为了更好的阅读体检,可以查看OJ上的题解。进入提交链接,点击右边菜单栏的"查看塔子哥的题解"

题目内容

塔子哥是一名数学老师,他正在为他的学生们准备一道有趣的数学题目。他想让他的学生们通过这道题目来锻炼他们的计算能力和创造力。这道题目是由塔子哥自己设计的,他希望通过这道题目来激发学生们对数学的兴趣和热情。题目如下:

塔子哥写下了一排 n n n 个数( n ≤ 2 n \leq 2 n2),依次用加号连接。

例如,塔子哥可能写下了如下的式子1+4+7+4+2+3+1共7个数以及6个加号。

假设塔子哥每次选择一个加号,将它改变成加减乘除中的一个(每次操作不对产生任何影响),问题是需要计算整个式子的后续操作产生影响。

现在,他想让你来帮助他验证一下这道题目的正确性,以便他可以在课堂上向他的学生们展示这道题目。

输入描述

第一行一个整数 n n n

接下来一行 n n n 个整数 a 1 , a 2 , … … , a n a_{1}, a_{2},……,a_{n} a1,a2,……,an依次表示塔子哥初始写下的连加算式中的每一个数。

接下来一个整数 m m m ,表示塔子哥做了 m m m 次算数训练

接下来 2 m 2m 2m 个以空格分开数字和符号 t 1 , o 1 , t 2 , o 2 , … … , t m , o m t_{1},o_{1}, t_{2}, o_{2},……,t_{m}, o_{m} t1,o1,t2,o2……tm,om,其中 t i t_{i} ti为数字, o i o_{i} oi是’+‘,’-‘,’*‘,’/'(即加减乘除,不含引号)中的一个符号,表示第i次操作选定第 t i t_{i} ti个加号,将其改变为了 o i o_{i} oi

对于所有的的数据 2 ≤ N ≤ 50000 , 1 ≤ M ≤ 50000 , 1 ≤ a i ≤ 500 , 1 ≤ t i < N , o i ϵ ( + , − , ∗ , / ) 2 \leq N \leq 50000, 1 \leq M \leq 50000 ,1 \leq a_{i} \leq 500,1 \leq t_{i} < N, o_{i} \epsilon (+,-,*,/) 2N500001M50000,1ai500,1ti<N,oiϵ(+,,,/)

输出描述

输出行m个整数,分别表示每次操作答案,结果四舍五入到第一位小数。

样例 1 1 1

输入

5
1 2 4 2 5
3
1 - 2 * 4 /

输出

10.0 16.0 7.4

样例解释
第一次操作后算数式为1-2+4+2+5 = 10.0

第二次操作后算数式为1+2*4+2+5 = 16.0

第三次操作后算数式为1+2+4+2/5 - 7.4

值得注意的是,每次操作都认为对初始的全加号式子(此处为1+2+4+2+5)进行操作,操作之间互不影响。

题目思路

思路:模拟

比较简单的一道题。先求一遍初始的总和。由于每次操作独立 , 所以每次先减去 + + + 的贡献,然后新增 新符号的贡献。输出即可。

但是这题的Go语言全军覆没。塔子哥不太熟悉Go语言。大家知道这题为什么Go没有输出,可以向塔子哥反馈!!

类似题目推荐

很签到的题目。几乎不涉及到算法。这里就不提供类似题目推荐了。

代码

C++

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e6 + 5;
double a[maxn];
int main (){
    int n;
    cin >> n;
    // s 代表初始的总和
    double s = 0;
    for (int i = 1 ; i <= n ; i++){
        cin >> a[i];
        s += a[i];
    }
    int m;
    cin >> m;
    cout.precision(1);
    cout << fixed;
    // 处理m次操作
    for (int i = 1 ; i <= m; i++){
        int x;
        char y;
        double t = s;
        cin >> x >> y;
        // + 就直接 忽略
        if (y == '+') ;
        // - , 总和 -= 2 * a[x]
        else if (y == '-') s -= 2 * a[x + 1];
        else if (y == '*'){
            // 减去原先的贡献
            s -= a[x] + a[x + 1];
            // 加上现在的贡献
            s += a[x] * a[x + 1];
        }else {
            // 减去原先的贡献
            s -= a[x] + a[x + 1];
            // 加上现在的贡献
            s += a[x] / a[x + 1];
        }
        cout << s;
        if (i != 2 * m) cout << " ";
        else cout << endl;
        // 还原
        s = t;
    }
    return 0;
}

python

import sys

n = int(input())  # 从标准输入中读入一个整数n
a = list(map(float, input().split()))  # 从标准输入中读入n个浮点数,分别存入数组a[]

s = sum(a)  # 计算这n个数的总和

m = int(input())  # 从标准输入中读入一个整数m,表示待处理的操作数

op = input().split()
for i in range(0 , 2 * m, 2):
    x, y = op[i : i + 2]
    x = int(x) - 1  # 将x转换成数组下标(Python下标从0开始)
    t = s  # 记录当前整数和s的和t,以备撤销操作时使用

    # 根据不同的操作符进行操作
    if y == '+':
        pass  # 不需要处理,继续下一步循环
    elif y == '-':
        s -= 2 * a[x + 1]  # 修改一个加号为减号,相当于将加号两边的数取了负,所以需要将s减去新加入的两个数(a[x+1]和-a[x+2])的和
    elif y == '*':
        s -= a[x] + a[x + 1]  # 修改一个加号为乘号,先将新修改的两个数从s中减去
        s += a[x] * a[x + 1]  # 加新的贡献
    else:
        s -= a[x] + a[x + 1]  # 修改一个加号为除号,先将新修改的两个数从s中减去
        s += a[x] / a[x + 1]  # 加新的贡献

    # 输出结果
    sys.stdout.write('{:.1f}'.format(s))
    if i != 2 * m - 1:
        sys.stdout.write(' ')  # 在输出数字之间加上空格(除了最后一个数字)
    else:
        sys.stdout.write('\n')
    
    s = t  # 修改完一个操作符后,需要将s恢复到操作前的状态t。

Java

java比较特殊,精度计算和其他语言不一样。参考题目讨论区。这里放一个AC的Java代码

import java.text.DecimalFormat;
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        
        // 读取数组的长度n
        int n = scanner.nextInt();
        int[] number = new int[n + 1];
        // 读取数组中n个元素
        for (int i = 1; i <= n; i++) {
            number[i] = scanner.nextInt();
        }
        
        // 计算前缀和,sum[i]表示number[1]~number[i]的总和
        double[] sum = new double[n + 1];
        for (int i = 1; i <= n; i++) {
            sum[i] = sum[i - 1] + number[i];
        }
        
        // 读取询问的数量m
        int m = scanner.nextInt();
        ArrayList<Double> ans = new ArrayList<>();
        // 处理每个询问
        for (int i = 0; i < m; i++) {
            // 获取询问的位置pos和操作符号ops
            int pos = scanner.nextInt();
            String ops = scanner.next();
            // 计算pos之前的元素总和left和pos之后元素的总和right
            double left = sum[pos - 1];
            double right = sum[n] - sum[pos + 1];
            double temp = 0;
            // 根据操作符计算temp的值
            if (ops.equals("-")) {
                temp = number[pos] - number[pos + 1];
            } else if (ops.equals("+")) {
                temp = number[pos] + number[pos + 1];
            } else if (ops.equals("*")) {
                temp = number[pos] * number[pos + 1];
            } else if (ops.equals("/")) {
                temp = (double) number[pos] / number[pos + 1];
            }
            // 将left、right和temp相加,并将结果添加到ans中
            ans.add(left + right + temp);
        }
        
        // 输出结果
        DecimalFormat decimalFormat = new DecimalFormat("0.0");
        for (int i = 0; i < m; i++) {
            System.out.printf(decimalFormat.format(ans.get(i)));
            System.out.print(" ");
        }
    }
}

Js

process.stdin.resume();
process.stdin.setEncoding('utf-8');
let input = '';
process.stdin.on('data', (data) => {
  input += data;
  return;
});
process.stdin.on('end', () => {
  const lines = input.trim().split('\n');
  let n = parseInt(lines[0].trim());
  let a = lines[1].trim().split(/\s+/).map((v) => parseFloat(v));
  let m = parseInt(lines[2].trim());
  let s = a.reduce((prev, cur) => prev + cur, 0);
  let ans = '';
  let op = lines[3].trim().split(/\s+/);
  for (let i = 0; i < 2 * m; i += 2) {
    var [x, y] = [op[i] , op[i + 1]];
    x -= 1;
    let t = s;
    if (y === '+') {
      // do nothing
    } else if (y === '-') {
      // 减两倍
      s -= 2 * a[x + 1];
    } else if (y === '*') {
      // 减去贡献,加上新贡献
      s -= a[x] + a[x + 1];
      s += a[x] * a[x + 1];
    } else {
      // 减去贡献,加上新贡献
      s -= a[x] + a[x + 1];
      s += a[x] / a[x + 1];
    }
    ans += s.toFixed(1);
    // 保证行末不含空格
    if (i !== 2 * m - 1) ans += ' ';
    // 还原
    s = t;
  }
  console.log(ans);
});

Go

存疑


package main

import (
    "bufio"
    "fmt"
    "os"
    "strconv"
    "strings"
)

func main() {
    scanner := bufio.NewScanner(os.Stdin)
    scanner.Scan()
    n, _ := strconv.Atoi(scanner.Text())

    a := make([]float64, n)
    scanner.Scan()
    for i, v := range strings.Fields(scanner.Text()) {
        a[i], _ = strconv.ParseFloat(v, 64)
    }

    scanner.Scan()
    _, _ = strconv.Atoi(scanner.Text())

    var s float64
    for _, v := range a {
        s += v
    }

    scanner.Scan()
    ops := strings.Fields(scanner.Text())

    for i := 0; i < len(ops); i += 2 {
        x, _ := strconv.Atoi(ops[i])
        x--
        var y = ops[i+1]

        t := s
        switch y {
        case "+":
            // do nothing
        case "-":
      // 减两倍
            s -= 2 * a[x+1]
        case "*":
      // 减去贡献,加上新贡献
            s -= a[x] + a[x+1]
            s += a[x] * a[x+1]
        case "/":
      // 减去贡献,加上新贡献
            s -= a[x] + a[x+1]
            s += a[x] / a[x+1]
        }

        fmt.Printf("%.1f", s)
        if i != len(ops)-2 {
            fmt.Print(" ")
        } else {
            fmt.Println()
        }

        s = t
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/585092.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

大数据分析案例-基于Adaboost算法构建糖尿病预测模型

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

华为OD机试之打印机队列(Java源码)

打印机队列 题目描述 有5台打印机打印文件&#xff0c;每台打印机有自己的待打印队列。 因为打印的文件内容有轻重缓急之分&#xff0c;所以队列中的文件有1~10不同的代先级&#xff0c;其中 数字越大优先级越高 打印机会从自己的待打印队列中选择优先级最高的文件来打印。 如…

5月29号软件资讯更新合集......

Paozhu C Admin 管理后台 1.4.0 版本发布 Paozhu C web 框架 1.4.0 版本发布。 提供一个完整的 admin 管理后台&#xff0c;支持图片管理&#xff0c;文件上传&#xff0c;修改百度开源编辑器 ueditor 上传管理程序为 c 框架自带 C ORM 框架&#xff0c;支持 HTTP/1 HTTP/2 …

InsCode AI 创作助手使用方法

CSDN最近推出了InsCode&#xff0c;可实现对话式AI辅助编程&#xff0c;能够帮助我们高效地创作文章&#xff0c;成倍提高生产力&#xff01;让我们一起来看看如何使用吧&#xff01; 首先&#xff0c;点击进入【发布】页面 右上角显示【创作助手】&#xff0c;可直接点击进入…

Tcl-10. 字符串比较,匹配,替换,类别,映射,string 相关

一、字符串比较&#xff1a;string compare, string equal 我们在 expr 和控制语句如 if、while 中可用比较运算符””、”!” 、“”、 “”等来进行字符串比较&#xff0c;但是如不注意的话就会产生问题。首先必须用双引号来将字符串值括起来&#xff0c;这样表达式语法分析…

​​​​Linux Shell 实现一键部署Oracle21 rpm包方式

oracle前言 Oracle开发的关系数据库产品因性能卓越而闻名&#xff0c;Oracle数据库产品为财富排行榜上的前1000家公司所采用&#xff0c;许多大型网站也选用了Oracle系统&#xff0c;是世界最好的数据库产品。此外&#xff0c;Oracle公司还开发其他应用程序和软件。同时&#…

【CTF】2023Ciscn WEB方向题解

前言 太菜了太菜了&#xff0c;太久没打比赛啥也不会做&#xff0c;部分题目可去NSSCTF进行复现:NSSCTF 比赛体验一般&#xff0c;一黑灯基本上题都烂掉 unzip 这道题估计大家都会&#xff0c;算是一道原题了 参考:https://xz.aliyun.com/t/10533 由于环境没了&#xff0c;靠…

基于复旦微FMQL45T900 全国产ARM+FPGA核心板方案

XM745D 是一款基于上海复旦微电子 FMQL45T900 的全国产化 ARM 核心板。该核心板将复旦微的 FMQL45T900&#xff08;与 XILINX 的 XC7Z045-2FFG900I 兼容&#xff09;的最小系统集成在了一个 87*117mm 的 核心板上&#xff0c;可以作为一个核心模块&#xff0c;进行功能性扩展&a…

《QDebug 2023年5月》

一、Qt Widgets 问题交流 1.在 VS 中双击打开 ui 文件后&#xff0c;过一会儿 Qt Designer 就闪退 我是在 Windows11 VS2019/2022 环境遇到这个问题&#xff0c;解决方法是设置 Run in detached window 为 True。 点击 "扩展->QT VS Tools->Options"&#…

通俗易懂理解到底什么是DevOps技术(Windows程序员视角)

我是荔园微风&#xff0c;作为一名在IT界整整25年的老兵&#xff0c;今天我们来聊聊到底什么是DevOps。 相信很多小伙伴为什么搞懂DevOps&#xff0c;已经不知道查了多少论坛的帖子和资料了&#xff0c;但还是很困惑的话&#xff0c;那不妨来看看我这个帖子。希望能有助于你的…

CASA模型NPP及碳源、碳汇模拟

CASA模型 CASA模型是一个基于过程的遥感模型(Potteret al&#xff0c;1993&#xff1b;Potter et al&#xff0c;1994)&#xff0c;耦合了生态系统生产力和土壤碳、氮通量&#xff0c;由网格化的全球气候、辐射、土壤和遥感植被指数数据集驱动。模型包括土壤有机物、微量气体通…

Android Jatpack--ViewModel

1.ViewModel ViewModel是Jetpack的一部分。 ViewModel类旨在以注重生命周期的方式存储和管理界面相关的数据。ViewModel类让数据可在发生屏幕旋转等配置更改后继续留存。 ViewModel出现的背景&#xff1a; ①职责分离 Android开发中&#xff0c;在页面较为简单的情况下&…

【社区分享 - 低代码篇】浪潮低代码引擎UBML和低代码平台inBuilder

【社区分享 - 低代码篇】浪潮低代码引擎UBML和低代码平台inBuilder 文章目录 【社区分享 - 低代码篇】浪潮低代码引擎UBML和低代码平台inBuilder1、inBuilder低代码平台介绍2、inBuilder低代码平台操作指导 1、inBuilder低代码平台介绍 1&#xff09;首先介绍了低代码平台相关背…

分布式应用之zookeeper集群+消息队列Kafka

1.Zookeeper集群的相关知识 1.1 zookeeper的概念 ZooKeeper是一个分布式的&#xff0c;开放源码的分布式应用程序协调服务&#xff0c;是Google的Chubby一个开源的实现&#xff0c;是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件&#xff0c;提供的功能…

00后卷王自述,我真的很卷吗?

前段时间我去面试了一个软件测试公司&#xff0c;成功拿到了offer&#xff0c;薪资也从10k涨到了18k&#xff0c;对于工作都还没两年的我来说&#xff0c;还是比较满意的&#xff0c;毕竟有些工作了3到4年的可能还没有我的高。 在公司一段时间后大家都说我是卷王&#xff0c;其…

CCP4i2之蛋白结构自动构建:Autobuild protein

在解析x射线蛋白晶体结构过程中&#xff0c;最常用的方法就是分子置换&#xff0c;即进行molecular replacement&#xff08;MR&#xff09;时&#xff0c;输入合适的同源蛋白作为model&#xff0c;以及目标蛋白的mtz和sequence&#xff0c;来完成相位解析的过程。 相位求解成…

TDengine 基于SpringBoot 框架和Druid 连接池的TDengine Demo示例

一、前文 TDengine 入门教程——导读 二、JDBC Demo下载 TDengine 官方提供的示例程序源码位于TDengine / TDengine 的 TDengine/examples/JDBC下: JDBCDemo&#xff1a;JDBC 最简单的demo。connectionPools&#xff1a;HikariCP, Druid, dbcp, c3p0 等连接池中使用 taos-jdb…

【刷题之路Ⅱ】迷宫问题升级版——找最短路径

【刷题之路Ⅱ】迷宫问题升级版——找最短路径 一、题目描述二、解题1、方法1——暴力递归更新栈1.1、思路分析1.2、先将栈实现以下1.3、代码实现 一、题目描述 原题连接&#xff1a; 地下迷宫 题目描述&#xff1a; 小青蛙有一天不小心落入了一个地下迷宫,小青蛙希望用自己仅…

C语言深度解析--操作符

目录 操作符 1.算数操作符 2.移位操作符 左移操作符<<&#xff1a; 右移操作符>>&#xff1a; 3.位操作符 按位与&&#xff1a; 按位或 | &#xff1a; 按位异或 ^ &#xff1a; 4.赋值操作符 5.单目操作符 6.关系操作符 7.逻辑操作符 8.条件操作…

这所985复试竟可直接加50分,若复试有科研经历!

本期为大家整理热门院校-“大连理工大学”的择校分析&#xff0c;这个择校分析专题会为大家结合&#xff1a;初试复试占比、复试录取规则&#xff08;是否公平&#xff09;、往年录取录取名单、招生人数、分数线、专业课难度等进行分析。希望能够帮到大家! –所有数据来源于研…