iOS-C_Day7___数组与二维数组

数组与函数

//1.给定某个字符数组,统计数组中所有英文字符的个数,比如“123fdd”中有 3 个。

//数组作为函数的接口参数, 数组的长度丢失

#include <string.h>

int numberOfCharacter(char src[], int len)

{

int cnt=0;

for (int i=0; i<len; i++) {

if ((src[i]>=‘A‘ && src[i]<=‘Z‘) || (src[i]>=‘a‘ && src[i]<=‘z‘)) {

cnt++;

}

}

return cnt;

}

/*int main(int argc, const char * argv[]) {

char str[200];

int len=0;

for (int i=0; i<200; i++) {

scanf("%c", &str[i]);

if (str[i]==‘\n‘) {

str[i]=‘\0‘;

break;

}

len++;

}

//    scanf("%s", str);

//    int len = (int)strlen(str);//求字符串中有效字符个数

printf("%d\n", numberOfCharacter(str,len));

return 0;

}*/

//判断一个整型数组是否是对称数组,例如{1,2,3,3,2,1}和{1,6,8,1,8,6,1}都是对称数组。

#include <stdbool.h>

//bool isSymmetricArray(int src[], int len)

//{

//    int i=0;

//    for (i=0; i<len/2; i++) {

//        if (src[i]!=src[len-i-1]) {

//            break;

//        }

//    }

//    if (i==len/2) {

//        return true;

//    }

//    return false;

//}

//int main(int argc,const char *argv[])

//{

//    int a[]={1,6,8,1,8,6,1};

//    printf("%d\n", isSymmetricArray(a,7));

//

//    return 0;

//}

//数组排序

//冒泡排序  从小到大

//9 7 8 5 6   --> 5 6 7 8 9

//第一次排序

//7 9 8 5 6

//7 8 9 5 6

//7 8 5 9 6

//7 8 5 6 9

//第二次排序

//7 8 5 6 9

//7 5 8 6 9

//7 5 6 8 9

//第三次排序

//5 7 6 8 9

//5 6 7 8 9

//第四次排序

//5 6 7 8 9

/*int main(int argc,const char *argv[])

{

int a[5]={9,7,8,5,6};

for (int i=0; i<5-1; i++) {//控制排序的次数

//        for (int j=0; j<5-1-i; j++) {//控制交换的次数

//            if (a[j]>a[j+1]) {

//                int temp = a[j];

//                a[j]=a[j+1];

//                a[j+1]=temp;

//            }

//        }

for (int j=1; j<5-i; j++)

{

if (a[j-1]>a[j]) {

int temp = a[j-1];

a[j-1]=a[j];

a[j]=temp;

}

}

}

for (int i=0; i<5; i++) {

printf("%d ", a[i]);

}

printf("\n");

}

*/

//选择排序

//9 7 8 5 6

//找最大值

//第一次排序

//6 7 8 5 9

//第二次排序

//6 7 5 8 9

//第三次排序

//6 5 7 8 9

//第四次排序

//5 6 7 8 9

//int main(int argc,const char *argv[])

//{

//    int a[5]={9,7,8,5,6};

//

//    for (int i=5-1; i>0; i--) {

//        int k = i;

//        for (int j=i-1; j>=0; j--) {

//            if (a[k]<a[j]) {

//                k=j;

//            }

//        }

//        if (k!=i) {

//            int temp = a[k];

//            a[k]=a[i];

//            a[i]=temp;

//        }

//    }

//    for (int i=0; i<5; i++) {

//        printf("%d ", a[i]);

//    }

//    putchar(‘\n‘);

//

//    return 0;

//}

//

//9 7 8 5 6

//找最小值

//k = i;

//第一次排序

//5 7 8 9 6

//第二次排序

//5 6 8 9 7

//第三次排序

//5 6 7 9 8

//第四次排序

//5 6 7 8 9

//int main(int argc,const char *argv[])

//{

//    int a[5]={9,7,8,5,6};

//

//    for (int i=0; i<5-1; i++) {

//        int k=i;

//        for (int j=i+1; j<5; j++) {

//            if (a[k]>a[j]) {

//                k=j;

//            }

//        }

//        if (k!=i) {

//            int temp = a[k];

//            a[k]=a[i];

//            a[i]=temp;

//        }

//    }

//

//    for (int i=0; i<5; i++) {

//        printf("%d ", a[i]);

//    }

//    putchar(‘\n‘);

//    return 0;

//}

//插入排序

//9 7 8 5 6

//第一次排序

//9 9 8 5 6

//7 9 8 5 6

//第二次排序

//7 9 9 5 6

//7 8 9 5 6

//第三次排序

//7 8 9 9 6

//7 8 8 9 6

//7 7 8 9 6

//5 7 8 9 6

//第四次排序

//5 7 8 9 9

//5 7 8 8 9

//5 7 7 8 9

//5 6 7 8 9

//

//int main(int argc,const char *argv[])

//{

//    int a[5]={9,7,8,5,6};

//    for (int i=1; i<5; i++) {

//        int temp = a[i];

//        int j=i-1;

//        while (j>=0 && a[j]>temp) {

//            a[j+1]=a[j];

//            j--;

//        }

//        a[j+1]=temp;

//    }

//    for (int i=0; i<5; i++) {

//        printf("%d ", a[i]);

//    }

//    putchar(‘\n‘);

//

//    return 0;

//}

//如何输入不定个数的数组元素

//int main(int argc,const char *argv[])

//{

//    int a[100];

//    int cnt=0;

//    for (int i=0; i<100; i++) {

//        scanf("%d", &a[i]);

//        cnt++;

//        //方法一

////        if (getchar()==‘\n‘) {

////            break;

////        }

//        //方法二

//        char ch;

//        if (scanf("%c", &ch), ch==‘\n‘) {

//            break;

//        }

//    }

//    for (int i=0; i<cnt; i++) {

//        printf("%d ", a[i]);

//    }

//

//    return 0;

//}

//二维数组可以看成由一维数组元素组成的数组

//int a[3][2];

//

//二维数组的初始化

//方法一

//int main(int argc,const char *argv[])

//{

//    int a[3][2]={1,2,3,4,5,6};

//

//    for (int i=0; i<3; i++) {

//        for (int j=0; j<2; j++) {

//            printf("%d ", a[i][j]);

//        }

//        printf("\n");

//    }

//    return 0;

//}

//方法二

//int main(int argc,const char *argv[])

//{

//    int a[3][2]={{1,2},

//                 {3,4},

//                 {5,6}};

//

//    for (int i=0; i<3; i++) {

//        for (int j=0; j<2; j++) {

//            printf("%d ", a[i][j]);

//        }

//        printf("\n");

//    }

//    return 0;

//}

//打印杨辉三角

//1

//1 1

//1 2 1

//1 3 3 1

//1 4 6 4 1

//1 5 10 10 5 1

/*int main(int argc,const char *argv[])

{

int a[10][10]={};

for (int i=0; i<10; i++) {

for (int j=0; j<i; j++) {

if (j==0 || j==i) {

a[i][j]=1;

}

else

{

a[i][j]=a[i-1][j]+a[i-1][j-1];

}

}

}

for (int i=0; i<10; i++) {

for (int j=0; j<i; j++) {

printf("%4d", a[i][j]);

}

printf("\n");

}

return 0;

}*/

int main(int argc,const char *argv[])

{

int a[10][10]={};

for (int i=0; i<10; i++) {

for (int j=0; j<=i; j++) {

if (j==0 || j==i) {

a[i][j]=1;

}

else

{

a[i][j]=a[i-1][j]+a[i-1][j-1];

}

}

}

for (int i=0; i<10; i++) {

printf("%*d", 26-2*i,a[i][0]);

for (int j=1; j<=i; j++) {

printf("%4d", a[i][j]);

}

printf("\n");

}

return 0;

}

时间: 2024-10-26 21:45:04

iOS-C_Day7___数组与二维数组的相关文章

JavaScript - 一维数组、二维数组基础

<html> <head> <head> <body> <script language="javascript"> // 数组 var arr = ["wjp", 520, 'wcc', 13.14] ; for(var i=0; i<arr.length; i++){ alert(arr[i]); } // 数组为空undefined var arr2 = ["wjp",,51

java数组(一维数组,二维数组)

数组初始化: 1,动态初始化:数组定义与为数组分配空间和赋值的操作分开进行 2,静态初始化:在定义数组的同时就为数组元素分配空间并赋值 3,默认初始化:数组是引用类型,它的元素相当于类的成员变量,因此,数组分配空间之后 每个元素也被按照成员的规则被隐士的初始化值 ------------------------------------------------. 一维数组: package day06; import java.util.Date; /*** * 数组演示 * 数组的声明: * t

C#一维数组,二维数组,多维数组

所谓的数组,就是相同数据类型的元素的元素按一定顺数排列的集合,就是把有限个类型相同的变量用一名字命名,然后用编号区分他们的变量的集合,这个名字成为数组名,编号称为下标.组成数组的各个变量成为数组的分量,也称为数组的元素,有时也称为下标变量,数组是在程序设计中,为了处理方便,把具有相同类型的若干变量按有序的形式组织起来的一种形式.这些按序排列的同类数据元素的集合成为数组. 数组又分为一维数组,二维数组,多维数组 一维数组用一个整数来索引,多维数组用两个或多个整数来索引. 一.数据类型[] 变量名

16.10.20 4th 1蛤蟆爬井 2一维数组 3二维数组

摘要 1蛤蟆爬井 2一维数组 3二维数组 例子 井深10米, 蛤蟆白天爬5m,晚上落4米,求几天爬出来. //思路,用循环语句来做,for因为是未知次数所以排除,while 先判断后运行排除, dowhile,先爬在判断所以可以 int gaodu = 0; int tianshu = 0; boolean tianse = true; do{ if(tainse){ //白天爬5米 gaodu+=5; //爬完后改黑天 tianse = false; //天数+1 tianshu +=1; }

一维数组,二维数组,三维数组,数组与指针,结构体数组,通过改变指针类型改变访问数组的方式

 打印数组中的每个元素,打印每个元素的地址: #include <stdio.h> #include <stdlib.h> void main(void) { int a[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; for (int *p = a; p < a + 10;p++)  //指针类型决定4个字节 { printf("\n%p,%d", p, *p); } getchar(); } 指针数组 #inclu

C/C++ 指针数组、二维数组

一. 二维数组 1> 初始化 int a[3][3] = { {1,0,0}, {0,1,0}, {0,0,1} }; // 这里是 {} , 而不是() 2> 将二维数组当做一维数组处理 void print_array( int * p, int row, int line) { for(int i=0; i<row; ++i) { for(int j=0; j<line; ++j) { printf("%d \n", *( p + i * row + j

C# 数组、一维数组、二维数组、多维数组、锯齿数组

C#  数组.一维数组.二维数组.多维数组.锯齿数组 一.数组: 如果需要使用同一类型的对象,就可以使用数组,数组是一种数据结构,它可以包含同一类型的多个元素.它的长度是固定的,如长度未知的情况下,请使用集合. 二.一维数组: 声明及初始化: class Program { static void Main(string[] args) { //方法一 int[] num = new int[3];//声明一个长度为3的值类型的数组: num[0] = 3;//为数组赋值: num[1] = 5

java基础中的一维数组和二维数组

1.数组:具有相同数据类型的一组数据的集合. 一维数组 2.创建一维数组 a.数组作为对象允许使用new关键字进行内存分配,使用数组之前,必须首先定义数组变量所属类型,即声明数组.  声明数组: 语法:数组元素类型   数组名字[]; 数组元素类型[]  数组名字: 注释:数组元素类型:决定了数组的数据类型,包括基本数据类型和费基本数据类型. 数组名字:为一个合法的标识符,自己去定义 []:指明该变量是一个数组类型变量,单个"[]"表示要创建的是一维数组. 例如:int arr[];

指针数组和二维数组指针变量

指针数组 概念: 一个数组的元素值为指针则是指针数组. 指针数组是一组有序的指针的集合. 指针数组的所有元素都必须是具有相同存储类型和指向相同数据类型的指针变量. 指针数组说明的一般形式为: 类型说明符 *数组名[数组长度] 其中类型说明符为指针值所指向的变量的类型. 例如: int *pa[3] 表示pa是一个指针数组,它有三个数组元素,每个元素值都是一个指针,指向整型变量. 1.用一个指针数组来指向一个二维数组. 指针数组中的每个元素被赋予二维数组每一行的首地址,因此也可理解为指向一个一维数

7、一维数组和二维数组耳朵创建,输出,Arrays.fill()替换

package com.xxx.xxx; import java.util.Arrays; public class demo8 { /** * 1.初始化一维数组 使用一维数组 * 2.初始化二维数组 使用二维数组 * 3.填充替换数组元素 * @param args */ public static void main(String[] args) { //1.第一种初始化方式 int arr[] = new int[]{1,2,3,4,5,6}; //一维数组 //1.1.第二种初始化方式