苏嵌 项目实战
姓名:唐茂华
日期: 2018.9.4
今日学习任务:学习c语言中栈的知识,定义函数完成进栈、出栈、清空栈等一系列操作。
今日任务完成情况:上课跟着老师,代码编写正常,编译没有问题。
课后作业:
1、请编写一个C函数,该函数将一个字符串逆序。
#include <stdio.h>
#include <string.h>
char *Stact(char *s)
{
int i;
int n = strlen(s)/2;
char num;
for(i = 0; i <= n; i++)
{
num = s[i];
s[i] = s[strlen(s)-i-1];
s[strlen(s)-i-1] = num;
}
return s;
}
int main()
{
char str[20];
printf("\n");
scanf("%s", str);
printf("%s\n", Stact(str));
return 0;
}
2、请编写一个C函数,该函数可以实现将一个整数转为任意进制的字符串输出。
#include <stdio.h>
#include <string.h>
int main()
{
char str[]="I am from shanghai";
printf("%s\n",str);
//puts (str);
char tmp;
char *p1 = str;
char *p2 = str + strlen(str) -1;
while (p1<p2)
{
tmp = *p1;
*(p1++) = *p2;
*(p2--) = tmp;
}
char *p3 = NULL;
p1 = str;
p2 = str;
while (*p2)
{
if (*p2 == ' ')
{
p3 = p2 - 1;
while (p1<p3)
{
tmp = *p1;
*(p1++) = *p3;
*(p3--) = tmp;
}
p1 = p2 + 1;
}
p2++;
}
p3 = p2 - 1;
while (p1<p3)
{
tmp = *p1;
*(p1++) = *p3;
*(p3--) = tmp;
}
//puts (str);
printf("%s",str);
return 0;
3、 输入一个字符串,计算字符串中子串出现的次数。
#include<stdio.h>
#include<string.h>
int fun(char *a, char *b)
{
int len_b;
int count = 0;
int num = 0;
char *temp = b;
len_b = strlen(b);
while (*a != '\0')
{
if (*a == *temp)
{
while ((*a == *temp) && (*a != '\0') && (*temp != '\0'))
{
num++;
a++;
temp++;
}
if (num == len_b)
{
count++;
}
num = 0;
temp = b;
}
else
{
a++;
}
}
return count;
}
int main()
{
char a[100];
char b[10];
int num;
printf("Enter the main string(<=100)!\n");
scanf("%s",a);
printf("Enter the substring(<=10)!\n");
scanf("%s",b);
num = fun(a,b);
printf("The number is:%d\n",num);
return 0;
}
4、 编写一个C函数,将”I am from shanghai ”倒置为”shanghai from am I”,即将句子中的单词位置倒置,而不改变单词内部结构。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main()
{
char *str[4];
char *ptr = "I am from shanghai";
int i, j;
for (i = 0; i<4; i++)
{
str[i] = (char *)malloc(sizeof(char) * 20);
}
for(i = 0; i < 4; i++)
{
ptr ++;
for (j = 0; j<20; j++)
{
if(*(ptr - 1) == ' ' || *(ptr - 1) == '\0')
{
break;
}
strncat(str[i],ptr - 1, 1);
ptr++;
}
}
for(i = 3; i >= 0; i--)
{
printf("%s ",str[i]);
}
printf("\n");
return 0;
}
今日未解决问题:不能独立编写程序。
今日收获:学习了C语言当中栈的相关知识。
自我评价: