c入门基础题(4)

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
  • 11
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值