[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 (aj > aj + 1) {

temp = aj;

aj = aj + 1;

aj + 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 && si>=gj){

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

}

}

return j;

}

int main() {

int m,n,i;

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

scanf("%d",&m);

int sm;

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

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

scanf("%d",&si);

}

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

scanf("%d",&n);

int gm;

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

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

scanf("%d",&gi);

}

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

return 0;

}

运行结果

相关推荐
Shadow(⊙o⊙)6 分钟前
进程间通信0.0-pipe()匿名管道,详细分析进程池调度队列执行逻辑,进程池模拟实现。
linux·运维·服务器·开发语言·c++
lcj25119 分钟前
【list】【手撕 STL】List 容器全解析!迭代器 / 增删改查 / 去重排序,面试必背的核心考点!
c++·面试·list
指尖的爷13 分钟前
C++头文件的作用
开发语言·c++
智者知已应修善业29 分钟前
【51单片机0.1秒计时到21.0时点亮LED】2024-1-5
c++·经验分享·笔记·算法·51单片机
apcipot_rain33 分钟前
计科八股20260606——二叉树、PCA、图深度学习、进程上下文、C语言预编译、文件读写、单精度浮点数
c语言·数据结构·算法·pca·图神经网络
你怎么知道我是队长33 分钟前
CRC校验介绍
c语言
scx_link36 分钟前
逻辑回归的总结
算法·机器学习·逻辑回归
zh路西法37 分钟前
【rosbridge-websocket】跨网络的ROS1与ROS2通讯法(上)
linux·网络·c++·python·websocket·网络协议
j7~40 分钟前
【C++】类和对象(下)--详解之再探构造函数,友元,static成员,类型转换等
开发语言·c++·类型转换·友元·匿名对象·内部类·编译器优化
稷下元歌41 分钟前
7天学会plc加机器视觉关于运动控制部份,配套视频在bib
开发语言·c++·git·vscode·python·docker·pip