学习日志 | 姓名:徐曹添 日期:2018.7.12 |
今日任务及完成情况 | 主要任务:指针、数组、函数 完成情况:应该还能勉强看懂吧。 |
(详细说明本日任务是否按计划完成,开发的代码量)
| 1.指针的定义、初始化和遍历。 2.指针函数和函数指针。 3.数组指针和指针数组。 4.指针和数组的赋值。 5.指针的值传递和址传递。 6.main函数。 8.指针的指针。 7.命令行参数。 |
今日开发中出现的问题汇总
难点还是指针。今日未解决问题
用命令行参数实现字符串冒泡排序。
今日开发收获
表示形式 | 含义 | 地址值 |
&a | 指向二维数组的指针 | 1000 |
a | 二维数组名,指向一维数组a[0],即第0行首地址 | 1000 |
a[0],*(a+0),*a | 第0行第0列元素地址 | 1000 |
a+1,&a[1] | 第1行首地址 | 1006 |
a[1],*(a+1) | 第1行第0列元素地址 | 1006 |
a[1]+2,*(a+1)+2,&a[1][2] | 第1行第2列元素地址 | 1010 |
*(a[1]+2),*(*(a+1)+2),a[1][2] | 第1行第2列元素的值 | 元素值为11 |
自我评价
(是否按开发规范完成
既定任务,需要改进的地方,与他人合作效果等)
难归难,还是要多看,多敲代码。用命令行参数实现:
1、字符串排序:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define SIZE 3
void sort(char *string[],int length)
{
int i,j;
char *t;
for(j=0;j<length-1;j++)
{
for(i=0;i<length-j-1;i++)
{
if(strcmp(string[i],string[i+1])>0)
{
t=string[i];
string[i]=string[i+1];
string[i+1]=t;
}
}
}
}
int main(int argc, char *argv[])
{
int i;
sort(argv,argc-1);
printf("The string after sort:\n");
for(i=1;i<argc;i++)//输出
{
printf("%s ",argv[i]);
}
while(1);
return 0;
}
2、冒泡排序:
#include <stdio.h>
void sort(int *a[],int argc)
{
int i, j, tmp;
for (i = 0; i < argc - 1; i++)
{
for (j = 0; j < argc - i - 1; j++)
{
if (a[j] < a[j + 1])
{
tmp = a[j];
a[j] = a[j + 1];
a[j + 1] = tmp;
}
}
}
}
void print(int *a[],int argc)
{
int i;
for (i = 1; i < argc; i++)
{
printf("%d ", a[i]);
}
printf("\n");
}
int main(int argc, int *argv[i])
{
sort(argv,argc);
print(argv,argc);
while (1);
return 0;
}