USACO Greedy Gift Givers

本文分享了一道USACO竞赛中关于财务分配的题目解答过程,通过定义结构体来存储参与者的名字和资金变动情况,并针对不同场景进行了详细解析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是我在USACO上做的第二道题,快被自己蠢哭

首先定义了一个全局结构变量,包含人名和钱。

然后读取总人数,定义相应大小的结构体数组。然后每次读取赠送者、赠送的金额、赠送的人数后,根据这些来读取受赠者并计算受赠者、赠送者的余额。

最后输出。

有一次程序超时是因为没有考虑赠送的金额和受赠者都为0的情况。

代码如下:


LANG: C

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct NP{
	char name[15];
	int money;
}mon;

void
main () {
    FILE *fin  = fopen ("gift1.in", "r");
    FILE *fout = fopen ("gift1.out", "w");
    int i,j;
    int renshu,money,num;//人数,赠送的钱,赠送的人数
    char zsz[15];//赠送的人
    char temp[15];
    while(fscanf(fin,"%d",&renshu)==1){ 
    	mon a[renshu];
    	for(i=0;i<renshu;i++){
    		fscanf(fin,"%s",&a[i].name);//读入人员
    		a[i].money=0;//初始化金钱
		}
    	while(fscanf(fin,"%s%d %d",zsz,&money,&num)==3/*赠送者、金额和人数*/){
    		j=0;
    		if(num==0) continue;
    		while(j<num){
    			fscanf(fin,"%s",&temp);
    			for(i=0;i<renshu;i++){
    				if(strcmp(temp,a[i].name)==0){
    					a[i].money+=money/num;//受赠者的余额
    					j++;
    					break;
					}
				}
			}
			for(i=0;i<renshu;i++){
				if(strcmp(zsz,a[i].name)==0){
					a[i].money+=money%num-money;//赠送者的余额
					break;
				}
			}
		}
		for(i=0;i<renshu;i++){
   			fprintf(fout,"%s %d\n",a[i].name,a[i].money);
		}
	}
	
    exit (0);
}

有于是初学者,代码肯定不够高效,希望您在看后能指出代码中的不足之处

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值