ios学习笔记--(c基础5)

一些简单的数组问题

test1()
定义⼀一个3⾏行5列的⼆二维数组,对其进⾏行随机赋值。
打印整个数组的最⼤大值、和。
打印第⼀一列的最⼤大值。
打印每列的最⼤大值。
按照列数打印该数组中的每个值。
将数组的⾏行和列交换,存储到另外⼀一个5⾏行三列的数组中。
test2()
输⼊入三个单词,查找并输出最⻓长单词。
test3()
有五个名字的字符串数组,按照英⽂文字⺟母的⼤大⼩小,进⾏行 升序排序。

test4()
1.随机对⼀一个2层4⾏行3列数组进⾏行赋值,求出最⼤大值、 和。
2.求上述数组的每层的最⼤大值、和。

//
//  main.m
//  C41 test
//
//  Created by dq on 15/7/20.
//  Copyright (c) 2015年 dq. All rights reserved.
//

#import <Foundation/Foundation.h>
void test1()
{
    int a[3][5],b[5][3];
    int max=0,max2=0,sum=0;
    int i,j;
    for ( i=0; i<3; i++) {
        for ( j=0; j<5; j++) {
            a[i][j]=arc4random()%100;
            max=a[i][j]>max?a[i][j]:max;
            sum+=a[i][j];
            printf("%d ",a[i][j]);

        }
        printf("\n");
        if (i==0) {
            printf("第一行的最大值%d\n",max);
        }

    }
    printf("sum==%d\n",sum);
    for ( j=0; j<5; j++) {
        for ( i=0; i<3; i++) {
            max2=a[i][i]>max2?a[i][j]:max2;

            b[j][i]=a[i][j];
            printf("%d ",b[j][i]);
        }
        printf("每一列的最大值%d ",max2);
        max2=0;
        printf("\n");
    }
}
void test2()
{
    char a[20][20];
    char b[20];
    int max=0;
    for (int i=0; i<3; i++) {
        printf("请输入单词\n");
        fgets(a[i],20, stdin);
        if ((int)strlen(a[i])>max) {
            strcpy(b, a[i]);
        }
    }
    printf("最长单词是%s",b);
}
void test3()
{
    char a[5][10]={"bbb","a","c","d","e"};
    char b[10];
    for (int i=0; i<5; i++) {
        for (int j=i+1; j<5; j++) {
            if(strcmp(a[i],a[j])>0)
            {
                strcpy(b, a[i]);
                strcpy(a[i], a[j]);
                strcpy(a[j], b);


            }
        }
    }
    for (int i=0; i<5; i++) {
        printf("%s\n",a[i]);   //%s 占位符  对应的事指针
    }
}

void test4()
{
    int a[2][4][3];
    int sum =0,max=0;
    int sum1=0,max1=0;
    for (int i=0; i<2; i++) {
        for (int j=0; j<4; j++) {
            for (int k=0; k<3; k++) {
                a[i][j][k]=arc4random()%100;
                sum+=a[i][j][k];
                max=a[i][j][k]>max?a[i][j][k]:max;
                max1=a[i][j][k]>max?a[i][j][k]:max;
                sum1+=a[i][j][k];

            }
        }

        printf("第%d层的最大值%d\n",i,max1);
        printf("第%d层的和%d\n",i,sum1);
        max1=0;sum1=0;

    }
    printf("最大值%d\n",max);
    printf("的和%d\n",sum);

}
int main(int argc, const char * argv[]) {
    @autoreleasepool {
        //test1();
        //test2();
        test3();
       // test4();
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值