[LeetCode-455]基于贪心算法的分发饼干问题的求解(C语言版)

/*

题目出处:LeetCode

题目序号:455. 分发饼干

题目叙述:假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。对每个孩子 i,都有一个胃口值 g[i],这是能让孩子们满足胃口的饼干的最小尺寸;并且每块饼干 j,都有一个尺寸 s[j] 。如果 s[j] >= g[i],我们可以将这个饼干 j 分配给孩子 i ,这个孩子会得到满足。你的目标是满足尽可能多的孩子,并输出这个最大数值。

*/

程序清单

#include <stdio.h>

// 冒泡排序

void bubble_sort(int *a, int length) {

int i, j, temp;

for (i = 0; i < length - 1; i++){

for (j = 0; j < length - 1 - i; j++){

if (a[j] > a[j + 1]) {

temp = a[j];

a[j] = a[j + 1];

a[j + 1] = temp;

}

}

}

}

// 分发饼干

int SplitBiscuit(int *s, int *g,int m, int n) {

int i = 0; // i 是饼干形状数组位标索引

int j = 0; // j 是孩子胃口数组位标索引

bubble_sort(s, m); // 对饼干形状数组排序

bubble_sort(g, n); // 对孩子胃口数组排序

for(i=0; i<m; i++) {

if(j<n && s[i]>=g[j]){

j++; // 如果可分发,位标移向下一个,否则不移动孩子

}

}

return j;

}

int main() {

int m,n,i;

printf("请输入饼干的数量:\n");

scanf("%d",&m);

int s[m];

printf("请输入每块饼干的尺寸大小:\n");

for (i=0; i<m; i++) {

scanf("%d",&s[i]);

}

printf("请输入孩子的数量:\n");

scanf("%d",&n);

int g[m];

printf("请输入每个孩子的胃口大小:\n");

for (i=0; i<n; i++) {

scanf("%d",&g[i]);

}

printf("一共可以满足 %d 个孩子的需求。\n",SplitBiscuit(s, g, m, n));

return 0;

}

运行结果

相关推荐
ALex_zry40 分钟前
C++ ORM与数据库访问层设计:Repository模式实战
开发语言·数据库·c++
RFdragon3 小时前
分享本周所学——三维重建算法3D Gaussian Splatting(3DGS)
人工智能·线性代数·算法·机器学习·计算机视觉·矩阵·paddlepaddle
浅念-5 小时前
Linux 开发环境与工具链
linux·运维·服务器·数据结构·c++·经验分享
旺仔.2916 小时前
容器适配器:stack栈 、queue队列、priority queue优先级队列、bitset位图 详解
c++
潜创微科技--高清音视频芯片方案开发7 小时前
2026年C转DP芯片方案深度分析:从适配场景到成本性能的优选指南
c语言·开发语言
刘景贤7 小时前
C/C++开发环境
开发语言·c++
Zero8 小时前
机器学习微积分--(1)核心思想
人工智能·算法·机器学习
青桔柠薯片8 小时前
从C语言到裸机运行:i.MX6ULL 的 GPIO 控制与编译链接过程分析
c语言·开发语言·imx6ull
OasisPioneer8 小时前
现代 C++ 全栈教程 - Modern-CPP-Full-Stack-Tutorial
开发语言·c++·开源·github
xiaobobo33309 小时前
c语言结构体相关箭头运算符和点号运算符的联系以及c语言的“索引”思想
c语言·箭头运算符·点号运算符·索引思想