news 2026/6/2 0:05:13

(新卷,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/5/28 14:49:33

基于SSM的电竞陪玩管理系统【源码+文档+调试】

&#x1f525;&#x1f525;作者&#xff1a; 米罗老师 &#x1f525;&#x1f525;个人简介&#xff1a;混迹java圈十余年&#xff0c;精通Java、小程序、数据库等。 &#x1f525;&#x1f525;各类成品Java毕设 。javaweb&#xff0c;ssm&#xff0c;springboot等项目&#…

作者头像 李华
网站建设 2026/5/28 18:27:28

Docker Compose配置共享数据卷实现PyTorch训练资源共享

Docker Compose配置共享数据卷实现PyTorch训练资源共享 在现代AI研发团队中&#xff0c;一个常见的场景是&#xff1a;多个开发者并行开展模型实验&#xff0c;有人训练ResNet&#xff0c;有人微调BERT&#xff0c;还有人做可视化分析。但很快就会遇到几个令人头疼的问题——数…

作者头像 李华
网站建设 2026/5/30 18:02:29

清华镜像源加速PyTorch相关依赖安装,配合CUDA镜像更流畅

清华镜像源加速PyTorch安装&#xff0c;结合CUDA容器实现高效AI开发 在深度学习项目中&#xff0c;最让人头疼的往往不是模型设计本身&#xff0c;而是环境搭建——尤其是当你面对“pip install torch 卡在 0%”、CUDA 版本不匹配报错、或者多台机器环境无法对齐的问题时。这种…

作者头像 李华
网站建设 2026/5/28 12:04:53

python flask django哈尔滨道路巡查报修信息管理系统vue 论文vue

目录已开发项目效果实现截图关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;已开发项目效果实现截图 同行可拿货,招校园代理 ,本人源头供货商 python flask django哈尔滨道路巡查报…

作者头像 李华
网站建设 2026/5/30 23:00:55

YOLOv11 Loss Landmark关键点损失:新增人脸检测支持

YOLOv11 Loss Landmark关键点损失&#xff1a;新增人脸检测支持 在智能安防、移动支付和虚拟现实等应用日益普及的今天&#xff0c;人脸检测早已不再是简单的“框出人脸”任务。越来越多的场景要求系统不仅能定位人脸&#xff0c;还要精确识别眼睛、鼻尖、嘴角等关键部位——这…

作者头像 李华