【PAT】1011/1016/1026/1046

22 篇文章 0 订阅
/*
*时间:2018年4月1日12:39:32-2018年4月1日13:09:15
*题号:1011   A+B和C
*语言:gcc 4.7.2
*分数:15
*题目描述:
给定区间[-231, 231]内的3个整数A、B和C,请判断A+B是否大于C。

输入格式:

输入第1行给出正整数T(<=10),是测试用例的个数。随后给出T组测试用例,每组占一行,顺序给出A、B和C。整数间以空格分隔。

输出格式:

对每组测试用例,在一行中输出“Case #X: true”如果A+B>C,否则输出“Case #X: false”,其中X是测试用例的编号(从1开始)。
输入样例:

4
1 2 3
2 3 4
2147483647 0 2147483646
0 -2147483648 -2147483647

输出样例:

Case #1: false
Case #2: true
Case #3: true
Case #4: false
*/

#include <stdio.h>

int main()
{
	int T;
	scanf("%d", &T);
	long a[T-1];                 //题目给的范围是[-2^31-2^31]所以不能用int类型
	long b[T-1];
	long c[T-1];	
	long i;
	for (i=0; i<=T-1; i++)
	{
		scanf("%ld", &a[i]);
		scanf("%ld", &b[i]);
		scanf("%ld", &c[i]);
	}
	for (i=0; i<=T-1; i++)
	{
		if (a[i] + b[i] > c[i])
			printf("Case #%d: true", i+1);   //注意输出的次数比数组下标大1
		else
			printf("Case #%d: false", i+1);
		printf("\n");
	}
	
	return 0;
}



/*
*时间:2018年4月1日14:49:37-2018年4月1日15:15:00
*题号:1016. 部分A+B
*语言:gcc 4.7.2
*分数:15
*题目描述:
正整数A的“DA(为1位整数)部分”定义为由A中所有DA组成的新整数PA。例如:给定A = 3862767,DA = 6,
则A的“6部分”PA是66,因为A中有2个6。现给定A、DA、B、DB,请编写程序计算PA + PB。
输入格式:

输入在一行中依次给出A、DA、B、DB,中间以空格分隔,其中0 < A, B < 10^10。

输出格式:

在一行中输出PA + PB的值。
输入样例1:

3862767 6 13530293 3

输出样例1:

399

输入样例2:

3862767 1 13530293 8

输出样例2:

0
*/

#include <stdio.h>

int main()
{
	long A;
	long B;
	int DA, DB;
	int PA = 0;
	int PB = 0;
	scanf("%ld", A);
	scanf("%d", DA);
	scanf("%ld", B);
	scanf("%d", DB);
	int i, temp;

	while (A != 0)               //检查A的每一位,每有一位与DA相同则右边加一个DA
	{
		temp = A % 10;
		if (DA == temp)
			PA = PA * 10 + DA;
		A /= 10; 
	}
	while (B != 0)
	{
		temp = B % 10;
		if (DB == temp)
			PB = PB * 10 + DB;
		B /= 10; 
	}
	
	printf("%d",PA + PB);
	return 0;
}




/*
*时间:2018年4月1日15:17:08-2018年4月1日15:49:39
*题号:1026. 程序运行时间
*语言:gcc 4.7.2
*分数:15
*题目描述:

要获得一个C语言程序的运行时间,常用的方法是调用头文件time.h,其中提供了clock()函数,可以捕捉从程序开
始运行到clock()被调用时所耗费的时间。这个时间单位是clock tick,即“时钟打点”。同时还有一个常数CLK_TCK
,给出了机器时钟每秒所走的时钟打点数。于是为了获得一个函数f的运行时间,我们只要在调用f之前先调用
clock(),获得一个时钟打点数C1;在f执行完成后再调用clock(),获得另一个时钟打点数C2;两次获得的时钟打
点数之差(C2-C1)就是f运行所消耗的时钟打点数,再除以常数CLK_TCK,就得到了以秒为单位的运行时间。

这里不妨简单假设常数CLK_TCK为100。现给定被测函数前后两次获得的时钟打点数,请你给出被测函数运行的时间。

输入格式:

输入在一行中顺序给出2个整数C1和C2。注意两次获得的时钟打点数肯定不相同,即C1 < C2,并且取值在[0, 10^7]。

输出格式:

在一行中输出被测函数运行的时间。运行时间必须按照“hh:mm:ss”(即2位的“时:分:秒”)格式输出;
不足1秒的时间四舍五入到秒。
输入样例:

123 4577973

输出样例:

12:42:59
*/
#include<stdio.h>

int main(void)
{
	int C1, C2;
	scanf("%d", &C1);
	scanf("%d", &C2);
	int times = (C2 - C1);
	times = times / 100;
	if ((C2 - C1)%100 >= 50)
		times++;
	int hh, mm, ss;
	hh = times / (60*60);
	mm = (times % (60*60)) / 60;
	ss = (times % (60*60)) % 60;
	printf("%02d:%02d:%02d",hh, mm, ss);  //注意输出格式%02d表示长度为两格,不满两格前面填0
	
	return 0;
}




/*
*时间:2018年4月1日15:51:08
*题号:1046. 划拳
*语言:gcc 4.7.2
*分数:15
*题目描述:
划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划
出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就赢了,输家罚一杯酒。两人同赢或两人同输
则继续下一轮,直到唯一的赢家出现。
下面给出甲、乙两人的划拳记录,请你统计他们最后分别喝了多少杯酒。

输入格式:

输入第一行先给出一个正整数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 T;
    scanf("%d", &T);
    if ( T == 0)
        printf("0 0");
    int num_J = 0;
    int num_Y = 0;
    int J_HAN[T-1];                 
    int J_HUA[T-1];
    int Y_HAN[T-1];    
    int Y_HUA[T-1];
    int i;
    for (i=0; i<T; i++)
    {
        scanf("%d", &J_HAN[i]);
        scanf("%d", &J_HUA[i]);
        scanf("%d", &Y_HAN[i]);
        scanf("%d", &Y_HUA[i]);
    }
    for (i=0; i<T; i++)
    {
        if(J_HUA[i] == Y_HUA[i])
        {
            continue;
        }        
        else if (J_HAN[i] + Y_HAN[i] == J_HUA[i])    
        {
            num_Y++; 
        }        
        else if (J_HAN[i] + Y_HAN[i] == Y_HUA[i])
        {
            num_J++; 
        }
    }
    printf("%d %d",num_J, num_Y);
    return 0;
}

/*
*之前continue那里把划和喊搞反了,一直只有14分,现在已经根正
*/



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值