当前位置: 首页 > news >正文

(新卷,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; }
http://www.zskr.cn/news/177109.html

相关文章:

  • Git Commit规范在AI项目中的应用:结合PyTorch环境管理
  • (新卷,100分)- 密码解密(Java JS Python C)
  • 本地无GPU也能炼丹?云端调用PyTorch-CUDA-v2.8镜像训练模型
  • Java计算机毕设之基于springboot的社区家政服务系统基于springboot的家政服务撮合与评价平台(完整前后端代码+说明文档+LW,调试定制等)
  • Git下载大文件LFS扩展使用指南:应对PyTorch模型体积大难题
  • 清华镜像源配置成功后仍无法加速?排查DNS污染问题
  • python flask django网约车司机在线叫预约系统vue
  • PyTorch-CUDA-v2.8镜像与Hugging Face Transformers无缝集成
  • Log4j2-CVE-2021-44228漏洞复现
  • Markdown语法进阶:用于编写高质量AI实验日志
  • OSSU数学课程:免费自学数学的完整路线图
  • 基于Java的基础设施智慧管理系统的设计与实现全方位解析:附毕设论文+源代码
  • 2025国内最新企业展厅服务商 TOP5 评测!服务深耕于四川、成都、广州、北京、云南等地区,国内优质企业展示服务厂家权威榜单发布,重塑企业展示新生态 - 全局中转站
  • 告别环境配置烦恼:PyTorch-CUDA-v2.8开箱即用深度学习环境
  • 12/29
  • Fastjson反序列化漏洞(1.2.24版本)
  • for myself
  • python flask django企业员工工资管理系统vue--03j8q
  • Conda List列出已安装包:检查PyTorch版本信息
  • 如何在PyTorch-CUDA-v2.8中安装额外Python包?方法总结
  • Git标签管理:为PyTorch模型版本打上里程碑
  • Docker Run参数详解:启动PyTorch容器的各类选项
  • 基于Java的塔吊租赁智慧管理系统的设计与实现全方位解析:附毕设论文+源代码
  • HuggingFace TrainingArguments参数详解:控制训练行为
  • 2025国内最新数字科技展厅企业top5推荐!服务深耕于四川、成都、广州、北京、云南等地区,国内优质数字展示服务厂家及品牌权威榜单发布,创新重构展示空间生态 - 全局中转站
  • YOLOv5部署到边缘设备:基于PyTorch Mobile的尝试
  • PyTorch Gradient Clipping:稳定大模型训练过程
  • GitHub Gist分享代码片段:快速传播PyTorch技巧
  • HuggingFace Inference API调用:无需GPU运行大模型
  • Jupyter Notebook单元测试:验证PyTorch函数正确性