蓝桥杯Python B组练习——芯片测试

一、题目

问题描述

有n(2≤n≤20)块芯片,有好有坏,已知好芯片比坏芯片多。

每个芯片都能用来测试其他芯片。用好芯片测试其他芯片时,能正确给出被测试芯片是好还是坏。而用坏芯片测试其他芯片时,会随机给出好或是坏的测试结果(即此结果与被测试芯片实际的好坏无关)。

给出所有芯片的测试结果,问哪些芯片是好芯片。
输入格式

输入数据第一行为一个整数n,表示芯片个数。

第二行到第n+1行为n*n的一张表,每行n个数据。表中的每个数据为0或1,在这n行中的第i行第j列(1≤i, j≤n)的数据表示用第i块芯片测试第j块芯片时得到的测试结果 ,1表示好,0表示坏,i=j时一律为1(并不表示该芯片对本身的测试结果。芯片不能对本 身进行测试)。
输出格式

按从小到大的顺序输出所有好芯片的编号
样例输入

3

1 0 1

0 1 0

1 0 1
样例输出

1 3

二、解析

给了总共有多少芯片,如样例中给了3个,在这n行中的第i行第j列(1≤i, j≤n)的数据表示用第i块芯片测试第j块芯片时得到的测试结果,也就是说第一列数据是三个芯片分别对第一块芯片的测试,以此类推。又因为好的芯片测试结果是准确的,并且好的比坏的多,所以好的结果大于总的一半就能确定他是好的芯片。

三、Python代码

复制代码
# 获取输入的总的芯片数
n = int(input())
# 获取输入的测试结果
arr = [list(map(int,input().split())) for i in range(n)]
tmp = [True]*n
for i in range(n):
    count = 0
    for j in range(n):
        if arr[j][i] ==0:
            count+=1
        if count >= n/2:
            tmp[i] = False
            break
for i in range(n):
    if tmp[i]==True:
        print(i+1,end="")

四、运行结果

五、视频讲解

http://【蓝桥杯比赛python组视频教程(零基础讲解+算法辅导)】https://www.bilibili.com/video/BV1Ma411B7TQ?p=11&vd_source=3f9b0ca3fcb4e76e1d57fb85a5746819

六、查漏补缺

双重for循环注意事项:

1.外层循环用来控制行数,内层循环用于控制列数;

2.外层循环的变量改动一次,内层循环需要从头到尾执行一遍(外层循环执行一次,内层循环跑一圈)

3.遇到几行几列时,使用双重循环,循环的嵌套不宜超过3层

end=" "

复制代码
a=0
for i in range(3):
    print()
    for j in range(3):
        a+=1
        print(a)

如上代码,没有end=" "时,运行结果:

有end=" "时运行结果:

七、最近刷到的有关的题

【深基4.习8】求三角形

## 题目描述

模仿例题,打印出不同方向的正方形,然后打印三角形矩阵。中间有个空行。

## 输入格式

输入矩阵的规模,不超过 9。

## 输出格式

输出矩形和正方形

## 样例 #1

### 样例输入 #1

复制代码
4
### 样例输出 #1
01020304
05060708
09101112
13141516

      01
    0203
  040506
07080910

python代码

复制代码
n = int(input())
num=1
for i in range(n):
    for j in range(n):
        print("%02d"%num,end="")
        num+=1
    print()
print()
num=1
for i in range(n):
    print("  "*(n-i-1),end="")
    for j in range(i+1):
        print("%02d"%num,end="")
        num+=1
    print()

运行结果:

相关推荐
念越1 小时前
蓝桥杯单元测试模拟1期模拟题答案及代码解析
蓝桥杯·单元测试·测试
小肝一下2 小时前
每日两道力扣,day4
c++·算法·leetcode·职场和发展
明灯伴古佛2 小时前
面试:synchronized用过吗,其原理是什么
面试·职场和发展
Mr_Xuhhh3 小时前
蓝桥杯复习清单真题(C++版本)
c++·算法·蓝桥杯
yoyobravery3 小时前
蓝桥杯第十二届4t满分
蓝桥杯
programhelp_3 小时前
IBM OA 高频真题分享|2026最新-Programhelp 独家整理
人工智能·机器学习·面试·职场和发展·数据分析
练习时长一年3 小时前
后端开发常用的skill推荐
人工智能·算法·职场和发展
念越4 小时前
蓝桥杯自动化测试模拟1期答案及代码解析(完整版)
自动化测试·软件测试·selenium·蓝桥杯
蒸汽求职4 小时前
低延迟系统优化:针对金融 IT 与高频交易,如何从 CPU 缓存行(Cache Line)对齐展现硬核工程底蕴?
sql·算法·缓存·面试·职场和发展·金融·架构
南山乐只4 小时前
Java并发工具:synchronized演进,从JDK 1.6 锁升级到 JDK 24 重构
java·开发语言·后端·职场和发展