最少停車數(C 語言)

題目描述

特定大小的停車場,數組cars[]表示,其中1表示有車,0表示沒車。車輛大小不一,小車占一個車位(長度1),貨車占兩個車位(長度2),卡車占三個車位(長度3)。

統計停車場最少可以停多少輛車,返回具體的數目。

輸入描述

整型字符串數組cars[],其中1表示有車,0表示沒車,數組長度小于1000。

輸出描述

整型數字字符串,表示最少停車數目。

用例

輸入1,0,1
輸出2
說明1個小車占第1個車位
輸入1,1,0,0,1,1,1,0,1
輸出3
說明1個貨車占第1、2個車位

給下面的代碼添加注釋(不要改動原本的代碼):

代碼

#include <stdio.h>
#include <stdlib.h>
#include <string.h>// 定義停車場車位最大數量常量
#define MAX_LEN 1000int main() {// 初始化輸入字符串數組,用于存儲用戶輸入的以逗號分隔的字符序列char input[MAX_LEN];// 讀取標準輸入(即從控制臺讀取一行數據),并去掉末尾換行符fgets(input, MAX_LEN, stdin);input[strcspn(input, "\n")] = '\0';// 初始化整型數組cars,用于存儲轉換為整數形式的車輛狀態int cars[MAX_LEN];int count = 0; // 記錄有效輸入的數量// 使用strtok函數按逗號分割輸入字符串,并將每個數字串轉換為整數存入cars數組char *token = strtok(input, ",");while (token != NULL) {cars[count++] = atoi(token); // 將當前token轉換為整數并存入cars數組token = strtok(NULL, ","); // 繼續處理下一個token}// 初始化臨時變量tmplen用于計算連續停車長度,res用于記錄最少可以停多少輛車int tmplen = 0;int res = 0;// 遍歷整個cars數組for (int i = 0; i < count; i++) {// 當前車位有車(用1表示)if (cars[i] == 1) {tmplen++; // 增加連續停車長度計數// 判斷是否到達最后一個車位或者下一個車位是空的(用0表示)if (i == count - 1 || cars[i + 1] == 0) {// 根據停車長度計算能夠停放的車輛數(卡車占3個車位,小車或貨車各占1或2個車位)res += tmplen / 3; // 先添加能完全停放的卡車數量if (tmplen % 3 != 0) { // 若剩余車位不足3個,則增加一輛車res++;}tmplen = 0; // 重置臨時停車長度計數器}}}// 輸出最少可以停多少輛車的結果printf("%d\n", res);return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/697592.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/697592.shtml
英文地址,請注明出處:http://en.pswp.cn/news/697592.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Rollup + Ts

Rollup Ts RollupTs demo 一、文件配置 | - src | | - utils | | | - .ts | | - .babelrc | | - main.js | | - style.css | - package.json | - rollup.config.js | - tsconfig.json二、插件下載 rollup // rollup 基本的包 typescript // ts 包 rollup/plug…

如何做bug分析 ?bug分析什么 ? 為什么要做bug分析 ?

每當我們完成一個版本測試時&#xff0c;總會在測試報告中添加一些分析bug的指標 &#xff0c;主要用于分析在測試過程中存在的問題 。但是在分析的過程中你就可能遇到如下的問題 &#xff1a; 我應該分析那些指標呢 &#xff1f;每一個具體的指標該如何分析 &#xff1f;它能說…

Vue3學習——computed、watch、watchEffect

computed 與Vue2.x中computed配置功能一致寫法 import {computed} from vuesetup(){...//計算屬性——簡寫let fullName computed(()>{return person.firstName - person.lastName})//計算屬性——完整let fullName computed({get()return person.firstName - perso…

算法——模擬

1. 什么是模擬算法&#xff1f; 官方一點來說 模擬算法&#xff08;Simulation Algorithm&#xff09;是一種通過模擬現實或抽象系統的運行過程來研究、分析或解決問題的方法。它通常涉及創建一個模型&#xff0c;模擬系統中的各種事件和過程&#xff0c;以便觀察系統的行為&a…

Redis緩存一致性問題(自用記錄)

背景 在開發過程中&#xff0c;redis緩存技術被大范圍應用。由于現在的系統大多是分布式的&#xff0c;高并發的&#xff0c;redis和傳統的數據庫&#xff0c;存在數據不一致的問題。 解決方案 本文主要探討兩者數據不一致的解決方案&#xff1a; 給緩存設置過期時間&#x…

dell戴爾電腦靈越系列Inspiron 15 3520原廠Win11系統中文版/英文版

Dell戴爾筆記本靈越3520原裝出廠Windows11系統包&#xff0c;恢復出廠開箱預裝OEM系統 鏈接&#xff1a;https://pan.baidu.com/s/1mMOAnvXz5NCDO_KImHR5gQ?pwd3nvw 提取碼&#xff1a;3nvw 原廠系統自帶所有驅動、出廠主題壁紙、系統屬性聯機支持標志、Office辦公軟件、MyD…

Jmeter接口測試 ,這應該是全網最詳細的教程了

&#x1f345; 視頻學習&#xff1a;文末有免費的配套視頻可觀看 &#x1f345; 關注公眾號【互聯網雜貨鋪】&#xff0c;回復 1 &#xff0c;免費獲取軟件測試全套資料&#xff0c;資料在手&#xff0c;漲薪更快 一、Jmeter 的使用步驟 打開Jmeter 安裝包&#xff0c;進入\bi…

postman-使用Postman的模擬服務來模擬(mock)后端數據,完成前端模擬API調用

最近項目上比較忙&#xff0c;任務多時間緊&#xff0c;導致后端開發任務繁多&#xff0c;無法及時開發完畢&#xff0c;但是前端同學已經把對應功能開發完成&#xff0c;需要進行前后端聯調來驗證API及一些交互問題&#xff1b;這不能因為后端的進度來影響前端的工作完成情況&…

【Linux進程】馮·諾依曼體系結構以及操作系統的深入理解

&#x1f4d9; 作者簡介 &#xff1a;RO-BERRY &#x1f4d7; 學習方向&#xff1a;致力于C、C、數據結構、TCP/IP、數據庫等等一系列知識 &#x1f4d2; 日后方向 : 偏向于CPP開發以及大數據方向&#xff0c;歡迎各位關注&#xff0c;謝謝各位的支持 目錄 1.馮諾依曼體系結構特…

kafka和ZK的關系

zk相當于是kafka的一個基礎設施 Kafka是一種高吞吐量、可擴展的分布式發布訂閱消息系統&#xff0c;ZooKeeper是一個分布式協調服務&#xff0c;用于管理和協調分布式系統中的各種資源 Zookeeper&#xff1a;管理broker&#xff0c;consumer 創建broker后&#xff0c;向zk注冊…

適用于生物行業的樣本管理系統

在生物樣本管理系統的應用中&#xff0c;我們首先需要了解生物樣本的特點和要求。生物樣本具有多樣性和易變性&#xff0c;需要被妥善保存和跟蹤&#xff0c;以確保其質量和可用性。 因此&#xff0c;一個有效的生物樣本管理系統需要具備以下特點&#xff1a; 全面性&#xff1…

Spring Event的原理以及缺陷

原理:Spring 事件監聽機制及原理分析 - Admol - 博客園 (cnblogs.com) 使用bug:Spring Event 別瞎用&#xff01;從我司的悲劇中&#xff0c;我總結了6 條最佳實踐&#xff01;-騰訊云開發者社區-騰訊云 (tencent.com)

2024最新任推邦邀請碼是什么

任推邦是一款非常受歡迎的推廣APP&#xff0c;任推邦邀請碼是【222222】獲得現金獎勵和提成獎勵用戶可以通過邀請好友加入來獲取收益。2024最新的任推邦邀請碼是【222222】&#xff0c;小編已經給大家整理好了他趣許多的邀請碼&#xff0c;想要領取獎勵的小伙伴快來和小編一起了…

聚合函數()不要隨意加空格

報錯&#xff1a;1630 - FUNCTION link.SUM does not exist. Check the Function Name Parsing and Resolution section in the Reference Manual 解決方法&#xff1a;count、avg、sum等函數后緊隨的()之間不能加空格&#xff0c;去掉這個空格即可&#xff0c;因為count()、a…

js 監聽元素是否出現在可視區域--IntersectionObserver

觀察者模式監聽判斷dom元素是否在可視區域內 本項目是使用vue3的寫法。 1.IntersectionObserver IntersectionObserver可以用來自動監聽元素是否進入了設備的可視區域之內&#xff0c;而不需要頻繁的計算來做這個判斷。由于可見&#xff08;visible&#xff09;的本質是&…

融中穿刺路徑角度評估的C++技術實現

消融模型的三維渲染 我們以肝部為例&#xff0c;通常肝部在做消融手術規劃時有幾個步驟。 一三維重建&#xff1a; 對器官進行圖像分割&#xff1b; 對腫瘤的原發區域GTV進行勾畫。 二穿刺路徑的規劃&#xff1a; 路徑規劃當中有幾個約束&#xff1a;穿刺深度、危及器官的…

OpenAI推出首個AI視頻模型Sora:重塑視頻創作與體驗

鏈接&#xff1a;華為OD機考原題附代碼 Sora - 探索AI視頻模型的無限可能 隨著人工智能技術的飛速發展&#xff0c;AI視頻模型已成為科技領域的新熱點。而在這個浪潮中&#xff0c;OpenAI推出的首個AI視頻模型Sora&#xff0c;以其卓越的性能和前瞻性的技術&#xff0c;引領著…

SpringBoot快速整合Thymeleaf實現文件上傳案例

SpringBoot快速整合Thymeleaf實現文件上傳案例 文章目錄 SpringBoot快速整合Thymeleaf實現文件上傳案例1. 創建工程2. pom.xml文件2. application.yml 配置3. 前端fileupload.html4. 后端Controller 本案例環境: SpringBoot: 2.3.0.RELEASEJDK: 1.8前端模板&#xff1a; thymel…

【PHP進階】Redis批處理緩存

大家好&#xff0c;我是程序員若風&#xff0c;又到了技術分享時刻。 概要 在某些場景下&#xff0c;我們需要頻繁的使用到緩存&#xff0c;比如需要獲取多個key值&#xff0c;如果采用單個拿緩存的辦法&#xff0c;會造成網絡IO極大的浪費&#xff0c;所以我們需要用戶Redis…

Leetcode3036. 匹配模式數組的子數組數目 II

Every day a Leetcode 題目來源&#xff1a;3036. 匹配模式數組的子數組數目 II 解法1&#xff1a;KMP 設數組 nums 的長度為 m&#xff0c;數組 pattern 的長度為 n。 遍歷數組 nums 的每個長度是 n1 的子數組并計算子數組的模式&#xff0c;然后與數組 pattern 比較&…