自学内容网 自学内容网

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)!