[codeup 1934] 找x
题目分析:
先循环输入,然后遍历数组中的元素,判断x与a[i]是否相等,相等则输出i;若循环结束时没有a[i]与X相等,则输出-1.
c++
#include <bits/stdc++.h>
using namespace std;
const int maxn=200;
int main()
{
int n,flag=-1,x;
int a[maxn];
cin>>n;
for(int i=0;i<n;i++)
cin>>a[i];
cin>>x;
for(int i=0;i<n;i++) //范围较小(最多200个数),遍历即可。
if(x==a[i])
{
cout<<i;
flag=1;
break;
}
if(flag==-1)
cout<<-1;
return 0;
}
python
n=int(input())
a=list()
flag=-1
a=list(map(int, input().split())) #将连续输入的n个数字存储到一个列表中
x=int(input())
for i in range(n-1): #遍历,寻找x的位置
if x==a[i]:
print(i)
flag=1
break
if flag==-1:
print(-1)
PAT B1036 跟奥巴马一起编程
题目分析:
四舍五入:如果是偶数,则行数为N/2;是奇数,则行数为(N+1)/2。然后循环逐行输出即可。
c++
#include <cstdio>
using namespace std;
int main()
{
int N,row;
char a;
scanf("%d %c",&N,&a);
if(N%2) row=(N+1)/2; //四舍五入
else row=N/2;
for(int i=0;i<N;i++)
printf("%c",a);
printf("\n");
for(int i=0;i<row-2;i++)
{
printf("%c",a);
for(int j=0;j<N-2;j++)
printf(" ");
printf("%c\n",a);
}
for(int i=0;i<N;i++)
printf("%c",a);
return 0;
}
python
N,a=list(map(str,input().split()))
N=int(N)
if N%2:
row=(N+1)/2
else:
row=N/2
row=int(row)
for x in range(N):
print(a,end="")
print("\n",end="")
for x in range(row-2):
print(a,end="" )
for i in range(N-2):
print(" ",end="")
print(a+"\n",end="")
for x in range(N):
print(a,end="")
笔记:
1.python的print()默认打印后换行,当需要自定义输出结尾的分割符号时,需在语句后添加end=,后面接需要的分割符号。如:
print(a,end="")
相当于输出末尾没有其他符号。
print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)
另外,print()中的sep参数用来间隔多个对象,默认值是一个空格,可以根据需要修改。
2.总结一下python中如何连续输入n个用空格隔开的元素:
·要解决这个问题首先学习两个方法:
(1)map(function, iterable, ...)
其中,第一个参数 function 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表。(function只有一个,但序列可以有多个)。
(2)str.split(str="", num=string.count(str))
split() 通过指定分隔符对字符串进行切片,如果第二个参数 num 有指定值,则分割为 num+1 个子字符串。
·str -- 分隔符,默认为所有的空字符,包括空格、换行(\n)、制表符(\t)等。
·num -- 分割次数。默认为 -1, 即分隔所有。
几种情况:
(1)如果输入的元素的类型都是一样的(指期望得到的类型)
则直接使用下面的语句,其中<type>可以是int,str等等。输入的数据被存储到列表n中。
n=list(map(<type>,input().split()))
(2)如果这些元素的类型有所不同:
N,a=list(map(str,input().split()))
N=int(N)
如上例,N为int型,a为str型。则先将数据都存储为str型,再将需要转换的进行类型转换(如本例中N)。