周总结<4>

经过了一周的学习,我们在html以及C语言方面又有的新的知识点的学习。


html


自习表格,函数等


C语言


哈弗曼编码

Html案例:

一.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>无标题文档</title>

</head>

<form name="form1" method="post" action="">

<table width="221" border="1"  cellpadding="0" cellspacing="0">

<tr>

<td height="30" colspan="2"> 用户登录</td>

</tr>

<tr>

<td width="59" height="30"> 用户名</td>

<td width="162" ><input name="user" type="text" id="user" /></td>

</tr>

<tr>

<td height="30" >密   码:</td>

<td> <input name="pwd" type="text" id="pwd"/></td>

</tr>

<tr>

<td height="30" colspan="2" align="center"><input name="Button" type="button" class="btn_grey" value="登录" onclick="check()" />

<input name="submint2" type="reset" class="btn_grey" value="重置" />

</td>

</tr>

</table>

</form>

<script type="text/javascript">

/*

P243 14-3

P246 14-6

P251 14-8 界面实现建议用表单的方式。

*/

var num1=120,num2=25;

document.write("120+25="+(num1+num2)+"<br >");

document.write("120-25="+(num1-num2)+"<br >");

document.write("120*25="+(num1*num2)+"<br >");

document.write("120/25="+(num1/num2)+"<br >");

document.write("(120++)"+(num1++)+"<br >");

document.write("(++120)="+(++num1)+"<br >");

var a=3;

var b="name";

var c=null;

alert("a的类型为:"+(typeof a)+"\nb的类型为:"+(typeof b)+"\nc的类型为:"+(typeof c));

function check()

{

var name=form1.user.value;

var pwd=form1.pwd.value;

if((name=="")||(name=null))

{

alert("请输入用户名");

form1.user.focus();

return;

}

else if((pwd=="")||(pwd=null))

{

alert("请输入密码");

form1.pwd.focus();

return;

}

else

{

form1.submit();

}

}

</script>

<body>

</body>

</html>

二.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>无标题文档</title>

</head>

<script type="text/javascript">

/*

P258  14-13  学习函数  countdown ,

1 明白参数传递实现,掌握 "id"属性作为实参的用法。

2 学会Date 的使用

3 尝试将countdown改写成switch ---case 的条件判断

4 页面实现改成成表单格式。

*/

function countdown(title,Intime,divId)

{

var online=new Date(Intime);

var now=new Date();

var leave =online.getTime()-now.getTime();

var day=Math.floor(leave/(1000*60*60*24))+1;

if(day>=0)

{

switch(day)

{

case 0:divId.innerHTML="<b>就是今天"+title+"呀!</b>";break;

case 1:divId.innerHTML="<b>-明天就是"+title+"啦!</b>";break;

default :divId.innerHTML="<b>-据"+title+"还有"+day+"天!</b>";break;

}

}

else

{

divId.innerHTML="<b>-哎呀"+title+"已经过了!</b>";

}

}

</script>

<body>

<table width="350" height="450" border="0" align="center" cellpadding="0" cellspacing="0">

<tr>

<td valign="bottom"><table width="346" height="418" border="0" cellpadding="0" cellspacing="0">

<tr>

<td width="76"> </td>

<td width="270">

<div id="countDown">

<b>-</b></div>

<script type="text/javascript">

countdown("2016年母亲节","5/8/2016",countDown);

</script>

</td>

</tr>

</table></td>

</tr>

</table>

</body>

</html>

C语言案例:

// 303.cpp : Defines the entry point for the console application.

//

#include "stdafx.h"

#include <stdio.h>

#include <string.h>

typedef char DataType;

struct element  //结点定义

{

DataType data;

float weight;//此字符的权值

int parent,lchild, rchild;//父结点,左孩子,右孩子存放位置

};

#define MAXLEAF 6  //最大叶子结点数目,待编码的字符数

#define MAXNODE MAXLEAF*2-1   //最大结点数

struct Huffmancode{

DataType ch;//存放字符

char bits[MAXLEAF];//存放字符的哈夫曼编码

};

Huffmancode hcode[MAXLEAF];

//element ht[ MAXNODE];

//此函数为选取两个最小的权值结点的位置 分别分别存放在pn[0],pn[1]

void Select (element *pt,int n, int *pn){

int i,iposi=0;

float tmp;

for(i=0;i<n;i++){

if(pt[i].parent==-1)

{

tmp=pt[i].weight;pn[0]=i;

iposi=i;

break;

}

}

for(i=iposi;i<n;i++){

if(tmp>pt[i].weight && pt[i].parent==-1){

pn[0]=i; tmp=pt[i].weight;

}

}

for(i=0;i<n;i++){

if(pt[i].parent==-1 && i!=pn[0])

{

tmp=pt[i].weight;pn[1]=i;

iposi=i;

break;

}

}

for(i=iposi;i<n;i++){

if(tmp>pt[i].weight && pt[i].parent==-1 && i!=pn[0]){

pn[1]=i; tmp=pt[i].weight;

}

}

return;

}

//此函数功能为创建哈夫曼树

void CreateHuffmanTree(element *pt){

int i,k=0;

int pn[2];

for(i=MAXLEAF ;i<MAXNODE;i++){

//选取两个最小的权值结点的位置 分别分别存放在pn[0],pn[1]

Select(pt,MAXLEAF+k,pn);

k++;

pt[pn[0]].parent=pt[pn[1]].parent=i;

pt[i].lchild=pn[0]; pt[i].rchild=pn[1];

pt[i].weight=pt[pn[0]].weight+pt[pn[1]].weight;

}

}

//此函数功能为生成哈夫曼编码

void CreateHuffmanCode(element *pt,int n){

int i,p,j,start;

char cd[MAXNODE];

for(i=0;i<n;i++){

start=n-1;

cd[start]=0;

p=pt[i].parent;

j=i;

//从叶子结点出发,逐层遍历到根结点,逆序求出每个结点的哈夫曼编码

while(p!=-1){//当p为 -1时,表示遍历到根结点

if(pt[p].lchild==j)

cd[--start]=‘0‘;//左孩子编码为0

else

cd[--start]=‘1‘; //右孩子编码为1

j=p;

p=pt[p].parent;

}

strcpy(hcode[i].bits,&cd[start]);

}

}

int main(int argc, char* argv[])

{

printf("303 柳晓雅\n");

element ht[MAXNODE];

int i;

for(i=0;i<MAXNODE;i++) {

ht[i].parent=-1;

ht[i].lchild=-1;

ht[i].rchild=-1;

ht[i].data=‘ ‘;

ht[i].weight=0;

}

//ht[0].data=‘A‘ ;ht[0].weight=2;  hcode[0].ch=ht[0].data;

//ht[1].data=‘B‘ ;ht[1].weight=4;  hcode[1].ch=ht[1].data;

//ht[2].data=‘C‘ ;ht[2].weight=5;  hcode[2].ch=ht[2].data;

//ht[3].data=‘D‘ ;ht[3].weight=3;  hcode[3].ch=ht[3].data;

ht[0].data=‘A‘ ;ht[0].weight=28;  hcode[0].ch=ht[0].data;

ht[1].data=‘B‘ ;ht[1].weight=13;  hcode[1].ch=ht[1].data;

ht[2].data=‘C‘ ;ht[2].weight=30;  hcode[2].ch=ht[2].data;

ht[3].data=‘D‘ ;ht[3].weight=10;  hcode[3].ch=ht[3].data;

ht[4].data=‘E‘ ;ht[4].weight=12;  hcode[4].ch=ht[4].data;

ht[5].data=‘F‘ ;ht[5].weight=7;  hcode[5].ch=ht[5].data;

CreateHuffmanTree(ht);//生成哈夫曼树

CreateHuffmanCode(ht,MAXLEAF);//生成哈夫曼编码

//输出每个字符的编码

float weight=0;

for(i=0;i<MAXLEAF;i++){

weight +=ht[i].weight*strlen(hcode[i].bits);

printf("字符=%c 权值=%f 编码=%s\n",hcode[i].ch, ht[i].weight,hcode[i].bits);

}

printf("weight=%f\n",weight);

return 0;

}

时间: 2024-08-26 13:42:33

周总结<4>的相关文章

周纪二

[周纪二]  起昭阳赤奋若,尽上章困敦,凡四十八年. 显王元年(癸丑,公元前三六八年) S催齐伐魏,取观津.古 S催赵侵齐,取长城.斋 显王三年(乙卯,公元前三六六年) S催魏.韩会于宅阳.知 S催秦败魏师.韩师于洛阳.古 显王四年(丙辰,公元前三六五年) S催魏伐宋.主 显王五年(丁巳,公元前三六四年) S催秦献公败三晋之师于石门,斩首六万.王赐以黼黻之服.古 显王七年(己未,前三六二年) 镳魏败韩师.赵师于浍.秦.魏战于少梁,魏师败绩:获魏公孙痤.主 S催卫声公薨,子成侯速立.知 S催燕桓

DJango周总结二:模型层,单表,多表操作,连表操作,数据库操作,事务

django周复习二 1,模型层:  1单表操作:   13个必会操作总结    返回QuerySet对象的方法有    all()    filter()    exclude()    order_by()    reverse()    distinct()    特殊的QuerySet    values()       返回一个可迭代的字典序列    values_list() 返回一个可迭代的元祖序列    返回具体对象的    get()    first()    last() 

中国mooc北京理工大学机器学习第一周(二)

---恢复内容开始--- 今天学习第一周的第二课时:降维. 一.PCA主成分分析 主成分分析(Principal Component Analysis,PCA),是一种统计方法,直观来讲是把数据按照weights来筛选出主成分消除(或者隐蔽)不太重要的方面,使得高纬度数据投射到低维度. 直观来讲是应用了统计学上方差和协方差的知识,若协方差越接近1则表示A,B越接近:反之,若等于零则无关. 这里可以理解在一个高纬度角度(n维空间)去找一个角度使得从你这个角度看过去很多cov(A,B)很小的数值为零

第13周 项目二-形状族中的纯虚函数

写一个程序,定义抽象基类Shape,由它派生出3个派生类,Circle(圆形).Rectangle(矩形).Triangle(三角形).用如下的main()函数,求出定义的几个几何体的面积和. int main() { Circle c1(12.6),c2(4.9);//建立Circle类对象c1,c2,参数为圆半径 Rectangle r1(4.5,8.4),r2(5.0,2.5);//建立Rectangle类对象r1,r2,参数为矩形长.宽 Triangle t1(4.5,8.4),t2(3

周总结二

总结 随着第二周的到来 学习也逐渐步入正轨 因为周二下午的讲座耽误了第二周的两次课 不过听完讲座深深觉得互联网是现在的发展趋势 而且有很好的就业前景 这让我突然打起精神要好好学习编程 学习技术 每天下课后的其余时间看了20分钟的代码大全 还看了姚老师课上给我们传的编程思想 学习是一点一点积累的 所以我要在学校积累各种实践经验  

第八周项目 二 【项目2-Time类中的运算符重载】

[项目2-Time类中的运算符重载] 实现Time类中的运算符重载. [cpp] view plaincopyprint? class CTime { private: unsigned short int hour;    // 时 unsigned short int minute;  // 分 unsigned short int second;  // 秒 public: CTime(int h=0,int m=0,int s=0); void setTime(int h,int m,i

第九周项目二-Time类中的运算符重载(续)

<span style="color: rgb(85, 85, 85); font-family: 'microsoft yahei'; font-size: 15px; line-height: 35px;">在Time类中的运算符重载基础上</span><br style="color: rgb(85, 85, 85); font-family: 'microsoft yahei'; font-size: 15px; line-height:

第十一周 &amp;十二周&amp;十三周周记

周数 专业学习目标 学习时间 新增代码行 博客发表量 人文方面学习 知识总结 第11周  掌握数据结构中图的定义与基本术语以及图的数据类型. 6 300 0 在网络上学习了有关UI的知识. 搞懂了图的基本概念和基本操作. 第12周 掌握网页中的CSS布局. 6 300 0 参见了防灾减灾的专题讲座 学会操作CSS3的属性选择器,结构性选择器. 第13周 掌握数据结构中图的存储结构以及树的遍历. 6 300 0 参加了关于英语四六级等级考试的讲座. 明白了图的深度广度优先遍历.

中国mooc北京理工大学机器学习第二周(二):回归

一.线性回归(Liner Regression) 利用数理统计中的回归分析,来确定两种或两种以上变量间相互依赖的定量关系的统计方法. 线性回归是用最小平方函数对一个或多个自变量和因变量之间进行建模. 导入和使用比较简单. from sklearn import linear_model linear = linear_model.LinearRegression() linear.fit(datasets_X, datasets_Y) 预测房屋价格. import matplotlib.pypl

第九周 项目二-Time类中的运算符重载(续)

在Time类中的运算符重载基础上 (1)定义对时间对象的自增和自减一目运算符 //一目运算符的重载 CTime operator++(int);//后置++,下一秒 CTime operator++();//前置++,下一秒,前置与后置返回值不一样 CTime operator--( int);//后置--,前一秒 CTime operator--();//前置--,前一秒 (2)定义Time类中的<<和>>运算符重载,实现时间的输入输出,改造原程序中对运算结果显示方式,使程序读起