news 2026/6/10 13:11:59

(新卷,100分)- 停车场车辆统计(Java JS Python C)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新卷,100分)- 停车场车辆统计(Java JS Python C)

(新卷,100分)- 停车场车辆统计(Java & JS & Python & C)

题目描述

特定大小的停车场,数组cars[]表示,其中1表示有车,0表示没车。

车辆大小不一,小车占一个车位(长度1),货车占两个车位(长度2),卡车占三个车位(长度3)。

统计停车场最少可以停多少辆车,返回具体的数目。

输入描述

整型字符串数组cars[],其中1表示有车,0表示没车,数组长度小于1000。

输出描述

整型数字字符串,表示最少停车数目。

用例
输入1,0,1
输出2
说明

1个小车占第1个车位

第二个车位空

1个小车占第3个车位

最少有两辆车

输入1,1,0,0,1,1,1,0,1
输出3
说明

1个货车占第1、2个车位

第3、4个车位空

1个卡车占第5、6、7个车位

第8个车位空

1个小车占第9个车位

最少3辆车

题目解析

这道题的意思应该是:给定了车位占用情况,如 1,1,0,0,1,1,1,0,1,这种车位占用情况,可能停了6辆车,即每个1都停了一个小车,这是最多的情况,但是现在要求最少可能停几辆车。

解题思路也很简单,先把卡车,即111的停车情况先弄出来,再将火车,即11的停车情况弄出来,最后再弄小车1的情况。

Java算法源码
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String str = sc.nextLine() .replaceAll(",", "") .replaceAll("111", "x") .replaceAll("11", "x") .replaceAll("1", "x"); int ans = 0; for (int i = 0; i < str.length(); i++) { if (str.charAt(i) == 'x') { ans++; } } System.out.println(ans); } }
JS算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { let str = line .replaceAll(",", "") .replaceAll("111", "x") .replaceAll("11", "x") .replaceAll("1", "x"); let count = 0; while (true) { let index = str.indexOf("x"); if (index !== -1) { count++; str = str.slice(index + 1); } else { break; } } console.log(count); });
Python算法源码
s = input().replace(",", "").replace("111", "x").replace("11", "x").replace("1", "x") ans = 0 for c in s: if c == 'x': ans += 1 print(ans)
C算法源码
#include <stdio.h> #include <string.h> #include <stdlib.h> /*! * 字符串替换 * @param s 主串 * @param sub 目标子串 * @param rep 替换子串 * @return 一个新串,新串等价于主串将自身目标子串部分替换为rep串的结果 */ char *replaceAll(char *s, char *sub, char *rep) { // 新串 char *res = (char *) calloc(strlen(s), sizeof(char)); // 目标子串长度 int len = (int) strlen(sub); // 在主串中找到目标子串第一次出现的位置 char *t = strstr(s, sub); while (t != NULL) { t[0] = '\0'; strcat(res, s); strcat(res, rep); s = t + len; t = strstr(s, sub); } strcat(res, s); return res; } int main() { char s[1000] = {'\0'}; int s_len = 0; char c; while (scanf("%c", &c)) { s[s_len++] = c; if (getchar() != ',') break; } // 先把卡车,即111的停车情况先弄出来(替换为x),再将火车,即11的停车情况弄出来(替换为x),最后再弄小车1的情况(替换为x)。 char *res = replaceAll(replaceAll(replaceAll(s, "111", "x"), "11", "x"), "1", "x"); int count = 0; // 统计x字符的数量,即为最少停车数量 int i = 0; while (res[i] != '\0') { if (res[i] == 'x') { count++; } i++; } printf("%d\n", count); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 22:48:53

清华镜像源配置后依旧慢?尝试更换上游节点

清华镜像源配置后依旧慢&#xff1f;尝试更换上游节点 在深度学习项目启动阶段&#xff0c;最让人焦头烂额的场景之一莫过于&#xff1a;明明已经配置了清华 TUNA 镜像源&#xff0c;却还是卡在 pip install torch 或 docker pull pytorch-cuda 上几个小时动弹不得。网速显示没…

作者头像 李华
网站建设 2026/6/10 13:15:50

PyTorch Distributed Sampler:多卡训练样本均匀分配

PyTorch Distributed Sampler&#xff1a;多卡训练样本均匀分配 在深度学习模型日益庞大的今天&#xff0c;单张 GPU 已经很难支撑动辄上百 GB 显存需求的训练任务。从 ResNet 到 BERT&#xff0c;再到如今的大语言模型&#xff0c;参数量的爆炸式增长迫使开发者转向多卡甚至多…

作者头像 李华
网站建设 2026/6/10 3:12:03

【多线程】CSP模式

CSP&#xff08;Communicating Sequential Processes&#xff09;模型详解 Actor vs CSP 对比 Actor 模型: ┌─────────┐ ┌─────────┐ │ Actor A │ ──msg──►│ Actor B │ 每个 Actor 有自己的邮箱 │ [邮箱] │ │ [邮箱] │…

作者头像 李华
网站建设 2026/6/9 23:46:10

Docker Run参数详解:启动PyTorch容器的各类选项

Docker Run参数详解&#xff1a;启动PyTorch容器的各类选项 在现代深度学习开发中&#xff0c;一个常见的场景是&#xff1a;你刚刚拿到一台配备NVIDIA GPU的新服务器&#xff0c;满心期待地准备开始训练模型&#xff0c;结果却卡在了环境配置上——CUDA版本不匹配、cuDNN缺失、…

作者头像 李华
网站建设 2026/6/10 10:29:21

如何在PyTorch-CUDA-v2.8中安装额外Python包?方法总结

如何在 PyTorch-CUDA-v2.8 中安装额外 Python 包&#xff1f;方法总结 在现代深度学习开发中&#xff0c;使用预构建的容器镜像已经成为标准实践。特别是像 PyTorch-CUDA-v2.8 这类高度集成的环境&#xff0c;极大简化了从本地实验到集群部署的流程。然而&#xff0c;现实项目往…

作者头像 李华