c入门基础题(3)
1、找出数组中最大元素的位置(下标值)
输入
多组测试,每组先输入一个不大于10的整数n 然后是n个整数
输出
输出这n个整数中最大的元素及下标值
样例输入
4
1 4 5 6
样例输出
6 3
#include<stdio.h>
int main(){
int a[20];
int n,x=0,y,z,s,m,f;
int i,j;
while(scanf("%d",&n)!=EOF){
for(i=1;i<=n;i++){
scanf("%d",&y);
a[x]=y;
x++;
}
if(x==1){
z=a[0];
f=0;
}
x=0;
for(j=1;j<=n-1;j++){
s=a[x];
m=a[x+1];
if(s>=m){
if(s>z){
z=s;
f=x;
}
}else{
if(m>z){
z=m;
f=x+1;
}
}
x++;
}
printf("%d %d\n",z,f);
x=0;
z=0;
f=0;
}
return 0;
}
2、数组中查找数,在给定的数组中查找一个数
输入
多组测试,每组第一行输入1个整数n(n<20),然后是n个整数 第二行输入1个整数m
输出
查找在第一行的n个整数中第一次出现数字m的下标位置并输出,如果没有找到则输出No
样例输入
3 4 5 6
5
4 2 2 2 2
2
样例输出
1
0
#include<stdio.h>
int main(){
int n;
while(scanf("%d",&n)!=EOF){
int a[n],m,flag=0,count=-1;
for(int i=0;i<n;i++)
scanf("%d",&a[i]);
scanf("%d",&m);
for(int i=0;i<n;i++){
//遍历寻找复合条件的数,找到则用count计数,flag=1表示找到
flag=0,count=-1;
if(m==a[i]){
count=i;
flag=1;
break;
}
}
if(flag==0) printf("No\n");
else printf("%d\n",count);
}
return 0;
}
3、数组中删数,在给定的数组中删除一个数
输入
多组测试,每组第一行输入1个整数n(n<20),然后是n个整数 第二行输入1个整数m
输出
删除在第一行的n个整数中第一次出现数字m并删除,然后按照顺序输出剩下的数, 最后一个数后面无空格
样例输入
4 1 2 3 4
3
样例输出
1 2 4
#include<stdio.h>
int main(){
int n;
while(scanf("%d",&n)!=EOF){
int a[n],m,count=20; //count用来记录数组中于m值相等的数的位置,初值不在0-19内
for(int i=0;i<n;i++)
scanf("%d",&a[i]);
scanf("%d",&m);
for(int i=0;i<n;i++){
//找到一个符合条件的数,记录他的下标并退回循环
count=20; //这个数组不多于20个数,所以设count为20,count没变则说明->
if(a[i]==m){
//->没有符合条件的m
count=i;
break;
}
}
int b[n]; //将原来的数组赋值给一个新数组,新数组中没有与m相同的数;
for(int i=0;i<n;i++){
if(i<count)
b[i]=a[i];
else
b[i]=a[i+1];
}
if(count==20){
//如果没有符合条件的,输出原数组
for(int i=0;i<n-1;i++)//count的值没变说明没有相同,输出数组
printf("%d ",a[i]);
printf("%d\n",a[n-1]);
}
else{
for(int i=0;i<n-2;i++)
printf("%d ",b[i]);
printf("%d\n",b[n-2]);
}
}
}
4、数组中删数II,在给定的数组中删除数
输入
多组测试,每组第一行输入1个整数n(n<20),然后是n个整数 第二行输入1个整数m
输出
删除在第一行的n个整数中的数字m(多个的话都要删除),然后按照顺序输出剩下的数,
样例输入
5 1 2 3 4 3
3
样例输出
1 2 4
#include<stdio.h>
int main(){
int n;
while(scanf("%d",&n)!=EOF){
int a[n],m,k=0;
for(int i=0;i<n;i++)
scanf("%d",&a[i]);
scanf("%d",&m);
int b[n]; //再创建一个新数组用以记录复合条件的数
for(int i=0;i<n;i++){
if(a[i]!=m){
b[k]=a[i];
k++;
}
}
if(k==0) printf("\n"); //如果没有符合条件的输出一个空行,有符合条件的,按序输出
else {
for(int i=0;i<k-1;i++)
printf("%d ",b[i]);
printf("%d\n",b[k-1]);
}
}
return 0;
}
5、数组中插入一个数,给定有序数组(从小到大),再给你一个数,要求插入该数到数组中并保持顺序
输入
多组测试,每组第一行输入一个整数n,然后是n个有序的整数 第二行输入1个整数m和1个整数K
输出
将整数m插入到原数组中保持顺序是升序,然后输出2行 第一行是插入以后的数组 第二行是插入以后的数组中下标值是K的数 n m k不超过20
样例输入
3 1 2 5
3 1
样例输出
1 2 3 5
2
#include<stdio.h>
int main(){
int n;
while
原文地址:https://blog.csdn.net/u010715243/article/details/138189262
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!