用c语言具体实现,设计一个生成树的代码。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用c语言具体实现,设计一个生成树的代码。相关的知识,希望对你有一定的参考价值。

数据结构方面。

/* 先序遍历法建立二叉树 */
#include "stdio.h"
#include "stdlib.h"

typedef char Datatype;
typedef struct BinTNode
Datatype data;
struct BinTNode *lchild, *rchild, *parent;
BinTree,*PBinTree;

void CreatBinTNode(BinTree *T) /* 建立二叉树 */

Datatype ch;
scanf("%c",&ch);
if(ch==\'@\') T=NULL;
else

T=(PBinTree)malloc(sizeof(BinTree) );
T->data=ch;
CreatBinTNode(T->lchild);
CreatBinTNode(T->rchild);



void PreOrder(BinTree *root)

if(root!=NULL)

printf("%c ",root->data);
PreOrder(root->lchild);
PreOrder(root->lchild);


void main()

BinTree T;
printf("按先序遍历的顺序输入二叉树,空的用@补全:\\n");
CreatBinTNode(&T);
printf("二叉树的先序遍历为 :\\n");
PreOrder(&T);


是自己实验用过的。。
参考技术A 网上去搜:二叉树生成源码 按照那个修改就可以了 参考技术B 太多例子来,找些代码来学习吧

C语言如何随机输出一个字符串?

比如说,我有100个人的名字(均大于一个字符),现在要求随机输出其中一人的名字?有人知道怎么设计这个程序么?不需要源码,只要思路就行。
PS:除了说什么建立100个变量,每个里面存个名字,最后用switch这种办法。这个不考虑

随机输出一个字符串,其实就是要随机生成一个字符串并输出。

要实现这一点,可以通过rand函数来实现。

具体示例代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define STR_LEN 10//定义随机输出的字符串长度。
#define CHAR_MIN \'a\'
#define CHAR_MAX \'z\' //定义输出随机字符串每个字符的最大最小值。
int main()

    char str[STR_LEN + 1] = 0;
    int i;
    
    srand(time(NULL));//通过时间函数设置随机数种子,使得每次运行结果随机。
    for(i = 0; i < STR_LEN; i ++)
    
        str[i] = rand()%(CHAR_MAX-CHAR_MIN + 1) + CHAR_MIN; //生成要求范围内的随机数。
    
    printf("%s\\n", str);//输出生成的随机数。
    
    return 0;

以上代码实现了随机生成一个长度为10,全部字符均为小写英文字符的字符串并输出。

核心语句为str[i] = rand()%(CHAR_MAX-CHAR_MIN + 1) + CHAR_MIN;

其中,

rand()获取一个随机数,

rand()%(CHAR_MAX-CHAR_MIN + 1)使结果位于[0, CHAR_MAX-CHAR_MIN]之内。这里利用了模除的特性。

这样最终的结果就是位于[CHAR_MIN, CHAR_MAX]之间的字符了,从而实现控制生成随机数据范围的效果。

参考技术A 字符串数组是必备的……不然很难实现……
如果每个名字都配有编号的话,就需要结构体了……然后使用结构体数组……
name[rand()%100] 就能得到一个名字了……
我觉得这是最简单的方法了……
当然,有数据库的话也可以……
建立一个表inf,有两个值ID和NAME
int i = rand%100;
select name from inf where id = i;本回答被提问者和网友采纳
参考技术B 用一个vector容器,里面存string。
假设你的名字在一个文本里,读文本,一行一个名字。用string保存之后存到你的容器里。
然后用随机数。
rand() % vector.size()得到一个随机的下标,用这个下标去取容器里的数据。
搞定
参考技术C 把人名放到大小为100的数组里,你可以从0到100中随机取一个数字,然后把这个数字作为元素下标,打印数组里这个下标对应的元素,就可以随机打出人名了。 参考技术D

    名字存数组,取数组下标,数组下标随机

    存字符串,用指定字符隔开。处理的时候分割字符到数组。还是取数组下标

以上是关于用c语言具体实现,设计一个生成树的代码。的主要内容,如果未能解决你的问题,请参考以下文章

急!数据结构最小生成树prim算法C语言实现

急!数据结构最小生成树prim算法C语言实现

图的遍历和生成树求解实现 (c语言版)

哈夫曼树(C语言实现)

急求KRUSKAL算法求最小生成树过程演示

二叉排序树的实现(c语言)