每周专业学习周记-1

每周专业学习周记-1

标签(空格分隔): 周记


说明:接下来的每一周都将会跟新我的专业学习周记,内容包括代码+总结。目前主要除了课程内的《数据结构与算法》课程之外,还有Python语言学习,Python作为现在比较热门并且易入门的编程语言,学习它无论是用作工具还是提升自己都会有很好的帮助,教材使用【美】《Python编程从入门到实践》。
接下来的每周我将会持续更新我的学习情况。

数据结构篇

#include <stdio.h>
#include <stdlib.h>
#define DataType char
int count;
typedef struct Node
{
    DataType data;
    struct Node* LChild;
    struct Node* RChild;
}BiTNode,*BiTree;

void GreateBiTree(BiTree *root)
{
    char ch;
    ch = getchar();
    if(ch=='#')
        *root = NULL;
    else
    {
        *root = (BiTree)malloc(sizeof(BiTNode));
        (*root)->data = ch;
        GreateBiTree(&((*root)->LChild));
        GreateBiTree(&((*root)->RChild));
    }
    
}

void PreOrder(BiTree root)
{
    
    if(root==NULL)
        return;
    else
    {
        printf("%c",root->data);
        PreOrder(root->LChild);
        PreOrder(root->RChild);
    }
}

void InOrder(BiTree root)
{
    if(root == NULL)
        return;
    else
    {
        InOrder(root->LChild);
        printf("%c",root->data);
        InOrder(root->RChild);
    }
}

void PostOrder(BiTree root)
{
    if(root == NULL)
        return;
    else
    {
        PostOrder(root->LChild);
        PostOrder(root->RChild);
        printf("%c",root->data);
    }
}

void PreLeaf(BiTree root)
{
    if (root!=NULL)
    {
        if (root->LChild==NULL && root->RChild==NULL)
            printf("%c",root->data);
        PreLeaf(root->LChild);
        PreLeaf(root->RChild);
    }

}

void InLeaf(BiTree root)
{
    if (root!=NULL)
    {
        InLeaf(root->LChild);
        if (root->LChild==NULL && root->RChild==NULL)
            printf("%c",root->data);
        InLeaf(root->RChild);
    }
    
}

void PostLeaf(BiTree root)
{
    if (root!=NULL)
    {
        PostLeaf(root->LChild);
        PostLeaf(root->RChild);
        if (root->LChild==NULL && root->RChild==NULL)
            printf("%c",root->data);
    }
}

void LeafCount(BiTree root)
{
    if (root!=NULL)
    {
        LeafCount(root->LChild);
        LeafCount(root->RChild);
        if (root->LChild==NULL && root->RChild==NULL)
            count++;
    }
}

int LeafCountB(BiTree root)
{
    int Count;
    if (root==NULL)
        Count = 0;
    else if(root->LChild==NULL && root->RChild==NULL)
        Count = 1;
    else
        Count = LeafCountB(root->LChild) + LeafCountB(root->RChild);
    return (Count);
}

int PostTreeDepth(BiTree root)
{
    int left,right,max;
    if (root!=NULL)
    {
        left = PostTreeDepth(root->LChild);
        right = PostTreeDepth(root->RChild);
        max = left>right?left:right;
        return(max+1);
    }
    else
        return(0);
}

int PreTreeDepth(BiTree root)
{
    int depth=0,h=1;
    h++;
    if(root != NULL) 
    {
        
        if (h>depth) depth = h;
        PreTreeDepth(root->LChild);
        PreTreeDepth(root->RChild);
    }
    return(h);
}

int main()
{
    BiTree root;
    GreateBiTree(&root);
    printf("先序遍历是:");
    PreOrder(root);
    printf("\n中序遍历是:");
    InOrder(root);
    printf("\n后序遍历是:");
    PostOrder(root);
    printf("\n前序遍历打印叶子节点:");
    PreLeaf(root);
    printf("\n中序遍历打印叶子节点:");
    InLeaf(root);
    printf("\n后序遍历打印叶子节点:");
    PostLeaf(root);
    
    LeafCount(root);
    printf("\n全局变量统计叶子节点个数为:");
    printf("%d",count);
    printf("\n分治算法统计叶子节点个数为:");
    printf("%d",LeafCountB(root));
    
    printf("\n后续遍历求二叉树的高度为:");
    printf("%d",PostTreeDepth(root));
    printf("\n先序遍历求二叉树高度的递归算法:");
    printf("%d ",PreTreeDepth(root));
    return 0;
}

数据结构小结

以上代码题目分别是:
(1)按照课本中二叉树的链式存储的定义,实现二叉树的链式定义,实现以下二叉树的创建(二叉树中存储的数据为字符类型数据,输入数据时候空子树用“#”):root指向根结点
(2)分别采用先序、中序、后序输出上述二叉树的结点数据信息。
(3)-(7)选作
(3)假设二叉树采用链接存储结构进行存储,root指向根结点,输出二叉树中的叶子结点。(先序,中序,后序)
(4)假设二叉树采用链接存储结构进行存储,root指向根结点,统计叶子结点数目(全局变量,分治算法)。
(5)假设二叉树采用链接存储结构进行存储,root指向根结点,求二叉树的高度。
递归算法的理解始终是有些难度,需要一层一层的慢慢通过栈的方式出栈入栈.

Python篇

#4.11遍历整个列表
magicians = ['alice','david','carolian']
for magician in magicians:
	print(magician)
#4.1.2 在for循环中执行更多的操作
magicians = ['alice','david','carolian']
for magician in magicians:
	print(magician.title()+",that was a great trick!")
	print("I can't wait to see your next trick, "+magician.title()+".\n")
#4.1.3在for循环之后执行一些操作
magicians = ['alice','david','carolian']
for magician in magicians:
	print(magician.title()+",that was a great trick!")
	print("I can't wait to see your next trick, "+magician.title()+".\n")
print("Thank you,everyone.That was a great magic show!")

#4.2.1 忘记缩进
# magicians = ['alice','david','carolian']
# for maician in magicians:
# print("I can't wait to see your next trick, "+magician.title()+".\n")
#IndentationError: expected an indented block 这个提示就是没有缩进

#4.2.2 忘记缩进额外的代码行
magicians = ['alice','david','carolian']
for magician in magicians:
	print(magician.title()+",taht was a great trick!")
print("I can't wait to see your next trick, "+magician.title()+".\n")

#4.2.3 不必要的缩进
# message = "Hello python world!"
# 	print(message)
#IndentationError: unexpected indent 这个提示是有不必要的缩进

#4.2.5 遗漏了冒号
# magicians = ['alice','david','carolian']
# for magician in magicians
# 	print(magician)
#SyntaxError: invalid syntax 语法错误,这里是for后面没有加封号

#4-1 披萨
pizzas = ['durian pizza','apple pizza','banana pizza']
for pizza in pizzas:
	print("I like "+pizza+".")

print("I really love banana pozza!")

#4-2 动物
dogs = ['teddy','husky','chinese rural dog']
for dog in dogs :
	print(dog.title()+" would like a great pet.")
print("Any of these animals would make a great pet!")

#4.3.1 使用range()函数
for value in range(1,5):
	print(value)

for value in range(1,6):
	print(value," ",end="")
print()
#4.3.2 用range()创建数字列表
numbers = list(range(1,6))
print(numbers)
#设置步长
even_numbers = (list(range(1,11,2)))
print(even_numbers)

squares = []
for value in range(1,11):
	square = value**2
	squares.append(square) 
print(squares)

squares = []
for value in range(1,11):
	squares.append(value**2)
print(squares)

#4.3.3 对数字列表执行简单的统计计算
digits = [10,2,3,4,5,6,65]
print(sum(digits),max(digits),min(digits))

#4.3.4 列表解析
squares = [value**2 for value in range(1,21)]
print(squares)

#4-3 数到二十
for value in range(1,21):
	print(value,end=" ")
print()
#4-4 一百万
# for value in range(1,1000000):
# 	print(value)

#4-5 计算1-1000000
#

#4-6 奇数
for value in range(1,20,2):
	print(value,end=" ")
print()

#4-7 三的倍数
number = [value for value in range(3,30,3)]
for num in number:
	print(num,end=" ")
print()
number = [value for value in range(1,30)]
for value in number:
	if value % 3 == 0:
		print(value,end=" ")
print()
#4-8 立方
number = []
for num in range(1,11):
	number.append(num**3)
for value in number:
	print(value,end=" ")

#4-9 立方解析
print()
number = [value**3 for value in range(1,11)]
print(number)

#4.4.1 切片
players = ['charles','martina','michael','florence','eli'] 
print(players[0:3])
print(players[1:4])
#如果没有指定第一个索引,python将自动从头开始
print(players[:4])
#同样的如果没有指定后一个索引,Python将自动从第一个索引开始访问后面的所有列表值
print(players[2:])
#如果想要输出最后三名队员的名字
print(players[-3:])
#如果想要输出倒数第三个队员之前的名字
print(players[:-3])

#4.4.2 遍历切片
players = ['charles','martina','michael','florence','eli']
print('Here are the first three players on my team.')
for player in players:
	print(player.title(),end=",")

#4.4.2 复制列表
my_foods = ['pizza','falafel','carrot cake']
friend_foods = my_foods[:]
print("\nmy favorite food are:")
print(my_foods)

print("my friend's favorite food are:")
print(friend_foods)
#这是从my_food里面提取了一个切片

#用切片的方式复制才能
my_foods = ['pizza','falafel','carrot cake']
friend_foods = my_foods[:]

my_foods.append('cannoli')
friend_foods.append('ice cream')

print("my favorite food are:")
print(my_foods)

print("my friend favorite food are:")
print(friend_foods)

print()
#用赋值的方式得到的效果只是两次都一样
my_foods = ['pizza','falafel','carrot cake']
friend_foods = my_foods
#python只是把两个变量关联起来了,而不是向上面一样做成一个副本
my_foods.append('cannoli')
friend_foods.append('ice cream')

print("my favorite food are:")
print(my_foods)

print("my friend favorite food are:")
print(friend_foods)

#4-10 切片
fruits = ['banana','apple','pear','tomato','watermelon']
print("The first there items in the list are:")
print(fruits[:3])
print(fruits[1:4])
print(fruits[-3:])

#4-11 披萨
my_pizzas = ['durian pizza','apple pizza','banana pizza']
friend_pizzas = my_pizzas[:]

my_pizzas.append("pear pizza")
friend_pizzas.append("tomato pizza")

print("My favorite pizzas are:")
for pizza in my_pizzas:
	print(pizza,end=",")
print()
print("My friend's favorite pizzas are:")
for pizza in friend_pizzas:
	print(pizza,end=",")
print()

#4.5.1 定义元组
dimensions = (200,50)
print(dimensions[0])
print(dimensions[1])
#修改元组的操作事被禁止的,python指出不能给元组的元素赋值
#dimensions[0] = 250

#4.5.2 遍历元组中的所有值
dimensions = (200,50)
for dimension in dimensions:
	print(dimension)

#4.5.3 修改元组变量
dimensions = (200,50)
print("Original dimensions:",end=" ")
for dimension in dimensions:
	print(dimension,end = " ")
print()

dimensions = (400,100)
print("modified dimensions:",end=" ")
for dimension in dimensions:
	print(dimension,end=" ")
#不能单独改变元组中的元素,但是可以使用元组的变量重新定义

#4-13 自助餐
print()
foods = ('milk','bread','egg','rice','apple')
for food in foods:
	print(food,end=" ")

#foods[0] = 'banana'
print()
foods = ('milk','bread','meat','rice','banana')
for food in foods:
	print(food,end=" ")

Python小结

在本章中,学习了:如何高效的处理列表中的元素;如何使用for循环遍历列表,python如何根据缩进来确定程序的结构以及如何避免一些常见的缩进错误;如何创建简单的数字列表,以及可对数字列表执行的一些操作;如何通过切片来使用列表的一部分和复制列表。还学习了元组(它对不应变化的值提供了一定程度的保护),以及在代码变的越来越复杂时如何设置格式,使其易于阅读。

posted @ 2020-05-10 18:23  稍微有点好看  阅读(509)  评论(2编辑  收藏  举报