标签:style blog io ar color os sp for on
1.数组
数组,快速定义多个变量.
数组定义: 数据类型 数组名[数组元素的个数] = {值1, 值2, 值 3};数组所占存储空间大小 = 数组元素个数 * 每个元素所占的存储空间大小.
%lu unsigned long 无符号的长整型. 无符号 >=0
sizeof 存储大小值 //用来计算一个变量,类型,以及数组所占存储空间的大小.
int a[5] = { 2, 7, 4, 3, 6 };
printf("%lu\n", sizeof(arr)); //5
int b[5] = { 2, 7, 4 }; printf("%lu\n", sizeof(arr)); //5
int c[5] = { 0 }; printf("%lu\n", sizeof(arr)); //5,因为定义的空间大小为5
int d[] = { 2, 7, 4, 3, 6 }; printf("%lu\n", sizeof(arr)); //5
</pre><pre>
获取数组中的元素:通过数组名 + 下标. c语言不会检测数组下标越界.
arr[5] = 20;
printf("%d",arr[5]);//角标越界
char arr[] = "ipho";
printf("%lu\n", sizeof(arr)); //存储空间大小为 5,因为有默认的\0 <pre name="code" class="cpp"><pre name="code" class="cpp"> printf("%lu\n", strlen(arr)); //字符串长度为 4
1.讲数组中的每一个元素输出
int arr[5] = {1, 3, 5, 6, 7};
for (int i = 0; i < 5 ; i++) {
printf("%d\n", arr[i]);
}
2.给数组中的每一个元素赋值 [20, 40]
int a[10] = {0};
for (int i = 0 ; i < 10; i++) {
a[i] = arc4random() % (40 - 20 + 1) + 20;
printf("a[%d] is %d\n", i, a[i]);
}
3.求数组中的最小值,给数组中的每一个元素赋值 [20 , 40].
int a[10] ={0};</span>
<span style="color:#000000;">for (int i = 0 ; i < 10; i++) {
a[i] = arc4random() % (40 - 20 + 1) + 20;
printf("a[%d] is %d\n", i, a[i]);
}
int min = 0;
for (int i = 0; i < 10; i++) {
if (i == 0) {
min =a[0];
} else {
if (min > a[i]) {
min = a[i];
}
}
}
printf("最大值为:%d\n", min); int arr[10] = {0};
for (int i = 0 ; i < 10 ; i++) {
arr[i] = arc4random() % ( 50 - 30 + 1 ) + 30;
printf("%d\n",arr[i]);
}
int sum = 0;
for (int i = 0; i < 10; i++) {
sum += arr[i];
}
printf("所有元素之和为:%d\n", sum);
2.数组排序
冒泡排序:
涉及到双循环:
外层循环控制趟数,外层减一, 可减可不减,-1目的是提供程序的执行效率.
内层循环控制比较次数. 内层减一,必须减,防止比较时越界.
内层 - i ,可以不减, -i目的是缩小无序区的范围,提高程序的执行效率.
代码如下:
int a[10] = {0};
for (int i = 0; i < 10; i++) {
a[i] = arc4random() % (15 - 10 + 1 ) + 10;
printf("%d ", a[i]);
}
for (int i = 0; i < 9; i++) {
for (int j = 0; j < 10 - 1 - i ; j++) {
if (a[j] < a[j+1]) { //降序排列
int temp =a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
}
printf("\n");
for (int i = 0; i < 10 ; i++) {
printf("%d " ,a[i]);
} char str[4]= {‘F‘, ‘R‘,‘‘,‘L‘,‘N‘};
printf("%lu\n",sizeof(str5));
char str[] = "phone"; //字符串
字符串隐藏字符 \0,作为字符串结束标志.
如果不指定元素个数,则系统开辟空间,会自动识别初始值的元素个数开辟空间.
char str5[]= {'F', 'R', 'L', 'N','d'};//如果定义空间大小[6],sizeof为6,长度为5
char str6[]="frln";
printf("str5 = %lu\n",sizeof(str5)); //空间大小为5
printf("str6 = %lu\n",sizeof(str6)); // 空间大小为5,隐藏\0
printf("str5 =%lu\n",strlen(str5)); // 长度5
printf("str33 =%s\n",str5); // FRLND
printf("str44 =%s\n",str6); // frln
printf("str6 =%lu\n",strlen(str6)); // 长度4
如何输出字符串?3.字符串处理
char str[10] = "language";
//字符串的长度.
printf("%lu\n", strlen(str)); //8
//字符串拷贝
strcpy(str ,"aa");
printf("%s\n",str); //因为有隐藏字符 \0,所以只能打印出aa.
//字符串 拼接
strcat(str,"bb");
printf("%s\n",str);//因为有隐藏字符 \0,所以只能打印出aabb.但是后面还存在值,如下
printf("%c\n",str[6]); // 结果为g
//字符串比较
printf("%d\n",strcmp("aa","bb")); // b - a = -1
printf("%d\n",strcmp("da","bb")); // (d -b) + (b - a ) =2
printf("%d\n",strcmp("bba","bb")); //如上 97标签:style blog io ar color os sp for on
原文地址:http://blog.csdn.net/zfx5130/article/details/41790455