划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就赢了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。
下面给出甲、乙两人的划拳记录,请你统计他们最后分别喝了多少杯酒。
输入格式:
输入第一行先给出一个正整数 N(≤100),随后 N 行,每行给出一轮划拳的记录,格式为:
甲喊 甲划 乙喊 乙划
其中喊是喊出的数字,划是划出的数字,均为不超过 100 的正整数(两只手一起划)。
输出格式:
在一行中先后输出甲、乙两人喝酒的杯数,其间以一个空格分隔。
输入样例:
5
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
输出样例:
1 2
方法一:利用一维数组,逐行计算
#include <stdio.h>
int main()
{
int n, i;
int jiahan, jiahua, yihan, yihua;
int jia = 0, yi = 0;
int sum = 0; //必须用sum来承担和运算
scanf("%d", &n);
for (i = 0; i < n; i++)
{
scanf("%d %d %d %d", &jiahan, &jiahua, &yihan, &yihua);
sum = jiahan + yihan; //必须用sum来承担和运算
if (jiahua == sum && yihua != sum)
{
yi++;
}
if (jiahua != sum && yihua == sum)
{
jia++;
}
}
printf("%d %d", jia,yi);
return 0;
}
方法二:利用动态数组
- 先定义一个二维指针**p
- 在利用二维指针对数组赋值时,先针对行数和列数分别申请空间(注意)
p = (int **)malloc(sizeof(int *)*n); //行数:n行
p[i] = (int *)malloc(sizeof(int)*4); //列数:4列
- 利用for循环赋值
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
int n;
int jia = 0, yi = 0, sum = 0;
int **p, i, j;
scanf("%d", &n);
p = (int **)malloc(sizeof(int *)*n); //行数:n行
for (i = 0; i < n; i++)
{
p[i] = (int *)malloc(sizeof(int)*4); //列数:4列
for (j = 0; j < 4; j++)
{
scanf("%d", &p[i][j]);
}
}
for (i = 0; i < n; i++)
{
sum = p[i][0] + p[i][2];
if (p[i][1] == sum && p[i][3] != sum)
{
yi += 1;
}
if (p[i][1] != sum && p[i][3] == sum)
{
jia += 1;
}
sum = 0;
}
free(p);
printf("%d %d", jia, yi);
return 0;
}
C++
#include<iostream>
using namespace std;
int main()
{
int n, jia0, jia1, yi0, yi1, sumJ = 0, sumY = 0, flagJ = 0, flagY = 0;
cin >> n;
for(int i = 0; i < n; i++)
{
cin >> jia0 >> jia1 >> yi0 >> yi1;
int sum = jia0 + yi0;
if(jia1 == sum && yi1 != sum) flagY++;
if(yi1 == sum && jia1 != sum) flagJ++;
}
cout << flagJ << " " << flagY;
}