百色市网站建设_网站建设公司_导航菜单_seo优化
2025/12/29 21:58:11 网站建设 项目流程

(新卷,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; }

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询