ccf201912-1报数

博客提到系统测试用例存在问题,其宣称n<=666,但提交后出现百位为7的测试用例,反映出测试用例设定与实际情况不符。

系统的测试用例不厚道啊,明明它自己说的n<=666,然后提交后就有测试用例百位为7的情况。

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
int main()
{
  	int n;
  	cin>>n;
  	int p[4]={0,0,0,0};
  	int count=1;
  	for(int i=1;count<=n;i++)
  	{
  		//printf("i=%d\n",i);
		if(i%7==0||i%10==7||i/10%10==7||i/100==7)
		{
			p[i%4]++;
			//printf("p[%d]=%d\n",i%4,p[i%4]);
		}else
		{
			count++;
			//printf("count=%d\n",count);
		}
		
	}
	for(int i=1;i<4;i++)
	{
		cout<<p[i]<<endl;
	}
	cout<<p[0]<<endl;
    return 0;
}
n = int(input())
count = 1
i = 1
p = [0 for i in range(4)]
def contain7(num): 
   # print('num=',num)
    #print(num-(num//10)*10)
    if(num%10 == 7):
        return True
    elif(num//10%10 == 7):
        return True
    elif(num//100 == 7):
        return True
    return False
while True :
    if(count == n+1): break  #第n次报数的时候也得判断一下
    #print('count=',count)
    if(i%7 == 0 or contain7(i)):
        #print(i,'=',i%4)
        p[i%4] += 1
    else :
        count += 1
    i += 1
for i in range(1,4):
    print(p[i])
print(p[0])

以下是几种使用C语言解决CCF CSP 20191201报数问题的实现方法: #### 方法一 ```c #include <stdio.h> int main () { int a = 0, //跳过甲的次数 b = 0, //跳过乙的次数 c = 0, //跳过丙的次数 d = 0; //跳过丁的次数 int i, n;//i为正在报的数,n为所报数字的个数,所报数字的最大值为(N+a+b+c+d) scanf("%d", &n); for (i = 1; i < (n+a+b+c+d); i++) { if (((i%7 == 0 || i%10 == 7) || i/10 == 7) || i/100 == 7) { switch (i%4) { case 0: d += 1; break; case 1: a += 1; break; case 2: b += 1; break; case 3: c += 1; break; default: break; } //测试用 //printf("%d %d %d %d %d %d %d\n",n,i,a,b,c,d,a+b+c+d); } } printf("%d\n%d\n%d\n%d\n", a, b, c, d); return 0; } ``` 此方法通过循环遍历报数过程,判断每个数是否需要跳过,根据取模结果更新每个人跳过的次数,最后输出结果[^1]。 #### 方法二 ```c #include <stdio.h> int skip(int a) //判断这个数字是否被跳过,如果被跳过,ret=1 { int ret = 0; if (a%7 == 0) ret = 1; while (a > 0 && !ret) { if (a%10 == 7) ret = 1; a /= 10; } return ret; } int main() { int a, b; scanf("%d", &b); //b表示报数次数 int i, k, u, n; //i、k、u、n 四个字母分别表示甲乙丙丁跳过的次数 i = k = u = n = 0; for (a = 1; a <= b; a++) { int t = skip(a); if (t) b++; //跳过的数字不计入总次数,所以b++ if (a%4 == 1 && t) { //用a对4取模来判断这个数字轮到谁说 i++; } if (a%4 == 2 && t) { k++; } if (a%4 == 3 && t) { u++; } if (a%4 == 0 && t) { n++; } } printf("%d\n%d\n%d\n%d", i, k, u, n); return 0; } ``` 该方法定义了一个`skip`函数用于判断数字是否需要跳过,在主函数中遍历报数过程,根据判断结果更新每个人跳过的次数并输出[^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值