花生采摘c语言编程答案,c语言贪心算法智力大冲浪与花生采摘两题

2023-10-17 23:40

本文主要是介绍花生采摘c语言编程答案,c语言贪心算法智力大冲浪与花生采摘两题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

满意答案

02ae427d08e371d7e90d5b995e828d6d.png

HWL0302

2014.08.13

02ae427d08e371d7e90d5b995e828d6d.png

采纳率:49%    等级:10

已帮助:322人

都是用C++写的,不建议只用纯C语言

#include

#include

#include

using namespace std;

struct Riddle {

int time;

int money;

};

struct gt{

bool operator()(Riddle& opl, Riddle& opr){

return opl.money > opr.money;

}

};

int main()

{

int m, n;

ifstream fin("riddle.in");

fin >> m >> n;

Riddle * riddles = new Riddle[n];

for (int i=0; i

fin >> riddles[i].time;

}

for (int i=0; i

fin >> riddles[i].money;

}

sort(riddles, riddles+n, gt() );

int * ridorder = new int[n];

for (int i=0; i

ridorder[i] = 0;

}

for (int i=0; i

int j;

for (j=riddles[i].time-1; j>=0 && ridorder[j]!=0; --j) {}

if (j >= 0) ridorder[j] = 1;

else m -= riddles[i].money;

}

cout << m << endl;

}

#include

#include

#include

#include

#include

#include

using namespace std;

#define maxn 55

struct Peanut

{

int x, y, num;

}peanut[maxn * maxn];

int n, m, t, pcount;

bool operator < (const Peanut &a, const Peanut &b)

{

return a.num > b.num;

}

void input()

{

pcount = 0;

scanf("%d%d%d", &n, &m, &t);

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

for (int j = 0; j < m; j++)

{

int a;

scanf("%d", &a);

if (a)

{

peanut[pcount].x = i + 1;

peanut[pcount].y = j + 1;

peanut[pcount].num = a;

pcount++;

}

}

}

void work()

{

int nowtime = peanut[0].x + 1;

if (nowtime + peanut[0].x > t)

{

printf("0\n");

return;

}

int ans = peanut[0].num;

for (int i = 1; i < pcount; i++)

{

nowtime += abs(peanut[i].x - peanut[i - 1].x) + abs(peanut[i].y - peanut[i - 1].y) + 1;

if (nowtime + peanut[i].x > t)

break;

ans += peanut[i].num;

}

printf("%d\n", ans);

}

int main()

{

//freopen("t.txt", "r", stdin);

int t;

scanf("%d", &t);

while (t--)

{

input();

sort(peanut, peanut + pcount);

work();

}

return 0;

}追问: c语言会吗 没有c语言告诉我思路也行 我不会c++ 不懂这是什么意思

追答:你除了头文件和输入输出看不懂应该都会的,如果你连结构体也看不懂就多学学吧

C++可以调用现成的库函数和模板,相对C来说只有优点

追问: 我就是在学啊 学的就是c 正在学 你写的c++好多看不懂 要是没有c语言的告诉我思路也行

00分享举报

这篇关于花生采摘c语言编程答案,c语言贪心算法智力大冲浪与花生采摘两题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/228729

相关文章

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

C语言实现两个变量值交换的三种方式

《C语言实现两个变量值交换的三种方式》两个变量值的交换是编程中最常见的问题之一,以下将介绍三种变量的交换方式,其中第一种方式是最常用也是最实用的,后两种方式一般只在特殊限制下使用,需要的朋友可以参考下... 目录1.使用临时变量(推荐)2.相加和相减的方式(值较大时可能丢失数据)3.按位异或运算1.使用临时

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st