【算法筆記】Codeup 100000572A

本專欄僅僅用於個人記錄刷題過程,如有更好的解決方法,可以留言哦

題目要求

完成一個對候選人得票的統計程序。假設有3個候選人,名字分別爲Li,Zhang和Fun。使用結構體存儲每一個候選人的名字和得票數。記錄每一張選票的得票人名,輸出每個候選人最終的得票數。結構體可以定義成如下的格式:

struct person {
    char name[20];
    int count;
}leader[3] = {“Li”, 0, “Zhang”, 0, “Fun”, 0};

要求輸入

第一行有一個整數n,表示以下有n張選票信息將會輸入。保證n不大於100。
以後的n行中,每一行包含一個人名,爲選票的得票人。保證每一個人名都是Li,Zhang和Fun中的某一個。

樣例

10
Li
Li
Fun
Zhang
Zhang
Fun
Li
Fun
Zhang
Li

要求輸出

有三行,分別爲Li,Zhang和Fun每人的得票數。格式爲首先輸出人名,其後輸出一個冒號,最後輸出候選人的得票數。
請注意行尾輸出換行。
樣例

Li:4
Zhang:3
Fun:3

可AC代碼如下

#include<stdio.h>
#include<string.h>
struct person {
	char num[20];
	int count;
}leader[3] = {"Li", 0, "Zhang", 0, "Fun",0};
int main(){
	int n;
	char str[20];
	//輸入n,n不大於0時才繼續運行,否則結束程序 
	while(1){
		scanf("%d",&n);
		getchar();
		if(n <= 100){
			break;
		}else{
			return 0;
		}
	}
	//開始選舉,只有輸入正確了,對應票數才加一	
	for(int i = 0; i < n; i++){
		gets(str);
		if(strcmp(str, "Li") == 0){
			leader[0].count++;
		}else if(strcmp(str, "Zhang") == 0){
			leader[1].count++;
		}else if(strcmp(str, "Fun") ==0){
			leader[2].count++;
		}else{
			return 0;
		}	
	}
	//開始唱票 
	for(int i = 0; i < 3; i++){
		printf("%s:%d\n", leader[i].num, leader[i].count);
	}	
	return 0;
}

遇到的問題

  • 如果在scanf()和gets()之間不加getchar()接收回車的話,本程序將直接結束

總結

  • 輸入輸出緩衝區的內容自行搜索(先挖坑,日後填)
  • gets()接收空格,以回車結束
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章