1.1 Greedy Gift Givers

来源:岁月联盟 编辑:exp 时间:2012-07-09

 这个题目比上个题目要稍微难一点,题目意思大概是有一群人,互相送money,要求送出的都是整数,每个人总共送出的money数量不一样,平均分给他的朋友们,不能送出的自己留下,每个人的朋友数量也不一样。要求从文件中读取数据,并运算算出最后每个人收到的money比送出的money多的数量。

     这个程序的关键是怎么处理凌乱的数据吧,我是定义结构体来保存每个人的数据的。程序中在使用strcmp()函数时出现了问题,我使用了判断语句 if(strcmp(name,person[i].name) 来判断两个字符数组是否相等,如果相等则执行if后面的操作,但这样写是错的,相等时strcmp()返回的是0,这样写的话适得其反。这是个很简单的错误,但相信有许多人都会犯这么简单的一个错误,所以我把他记下来,以免以后会犯同样的错误。

   

 01 /* 

02 ID: whutzha1 

03 PROG: gift1 

04 LANG: C++ 

05 */

06 #include<fstream> 

07 #include<string.h> 

08 using namespace std; 

09 ifstream cin("gift1.in"); 

10 ofstream cout("gift1.out"); 

11   

12 struct Node 

13 { 

14   char name[14]; 

15   int  give; 

16   int  rest; 

17   int  friends;  //朋友数量 

18   int  friends_num[10];  //保存朋友的下标 

19 }; 

20   

21 int main() 

22 { 

23    int i,j,k,m,num; 

24    cin>>num; 

25    Node person[10]; 

26    char name[14]; 

27   

28    for(i=0;i<num;i++) 

29    { 

30      cin>>person[i].name; 

31    } 

32   

33    for(i=0;i<num;i++) 

34   { 

35      cin>>name; 

36      for(j=0;j<num;j++) 

37      { 

38        if (strcmp(name,person[j].name)==0) 

39        { 

40        cin>>person[j].give; 

41        cin>>person[j].friends; 

42        break; 

43        } 

44      } 

45      for(m=0;m<person[j].friends;m++) 

46      { 

47         cin>>name; 

48         for(k=0;k<num;k++) 

49         { 

50             if (strcmp(name,person[k].name)==0)  {person[j].friends_num[m]=k;break;} 

51         } 

52      } 

53      } 

54    for(i=0;i<num;i++)   {person[i].rest=0;} 

55    for(i=0;i<num;i++)   

56    {   

57      if (person[i].give)   

58      { 

59        person[i].rest+=(person[i].give%person[i].friends); 

60        for(j=0;j<person[i].friends;j++) 

61        { 

62            person[person[i].friends_num[j]].rest+=(person[i].give/person[i].friends); 

63        } 

64      } 

65 } 

66   

67    for(i=0;i<num;i++) 

68    { 

69      cout<<person[i].name<<" "<<person[i].rest-person[i].give<<endl; 

70    } 

71    return 0; 

72 }