汉明码c语言
A. c语言与汉字区位码
汉子区位码是一个ASCII码只要将其以十六进制输出,就是区位码了。是有两个16进制数组成,建议网络一下区位码的原理自然迎刃而解。
B. 用c++编写汉明码【(7,4)汉明码】生成程序
hanmingma=round(rand(7,4));hanmingma_wucha=hanmingma;for i=1:4 row=ceil(rand*7); hanmingma_wucha(row,i)=~(hanmingma_wucha(row,i));end
这个是函数表示:
做成函数的形式hanmingma_wucha=function(hanmingma)hanmingma_wucha=hanmingma;for i=1:4 row=ceil(rand*7); hanmingma_wucha(row,i)=~(hanmingma_wucha(row,i));end保存成一个m文件即可
C. 关于C语言的
那个重新下载也是没有的,因为有部分是别人自写的函数.
下面的代码是iostream.h的源文件. 有具体的问题可以发消息问.
/***
*iostream.h - definitions/declarations for iostream classes
*
* Copyright (c) 1990-1997, Microsoft Corporation. All rights reserved.
*
*Purpose:
* This file defines the classes, values, macros, and functions
* used by the iostream classes.
* [AT&T C++]
*
* [Public]
*
****/
#if _MSC_VER > 1000
#pragma once
#endif
#ifdef __cplusplus
#ifndef _INC_IOSTREAM
#define _INC_IOSTREAM
#if !defined(_WIN32) && !defined(_MAC)
#error ERROR: Only Mac or Win32 targets supported!
#endif
#ifdef _MSC_VER
// Currently, all MS C compilers for Win32 platforms default to 8 byte
// alignment.
#pragma pack(push,8)
#include <useoldio.h>
#endif // _MSC_VER
/* Define _CRTIMP */
#ifndef _CRTIMP
#ifdef _DLL
#define _CRTIMP __declspec(dllimport)
#else /* ndef _DLL */
#define _CRTIMP
#endif /* _DLL */
#endif /* _CRTIMP */
typedef long streamoff, streampos;
#include <ios.h> // Define ios.
#include <streamb.h> // Define streambuf.
#include <istream.h> // Define istream.
#include <ostream.h> // Define ostream.
#ifdef _MSC_VER
// C4514: "unreferenced inline function has been removed"
#pragma warning(disable:4514) // disable C4514 warning
// #pragma warning(default:4514) // use this to reenable, if desired
#endif // _MSC_VER
class _CRTIMP iostream : public istream, public ostream {
public:
iostream(streambuf*);
virtual ~iostream();
protected:
iostream();
iostream(const iostream&);
inline iostream& operator=(streambuf*);
inline iostream& operator=(iostream&);
private:
iostream(ios&);
iostream(istream&);
iostream(ostream&);
};
inline iostream& iostream::operator=(streambuf* _sb) { istream::operator=(_sb); ostream::operator=(_sb); return *this; }
inline iostream& iostream::operator=(iostream& _strm) { return operator=(_strm.rdbuf()); }
class _CRTIMP Iostream_init {
public:
Iostream_init();
Iostream_init(ios &, int =0); // treat as private
~Iostream_init();
};
// used internally
// static Iostream_init __iostreaminit; // initializes cin/cout/cerr/clog
#ifdef _MSC_VER
// Restore previous packing
#pragma pack(pop)
#endif // _MSC_VER
#endif // _INC_IOSTREAM
#endif /* __cplusplus */
D. c语言 汉若塔的代码
汉诺塔是一种典型的递归思想。
以这例子来说,就是如果想把N个盘子从A移到C,就先把最上面的N-1盘子从A移到B,然后把最底边的盘子移到C, 再把B里的盘子移到C。
这种思想,举个例子。让你求1+2+3+。。。。。。+N。
递归思想的解法是,如果我知道n-1个数的和,那么式子的和就是Sn-1 + N;
写个函数就是:
intsum(intn){
if(n==1){
return1;//结束条件,没有这个条件,函数永远不会结束。
}else{
returnsum(n-1)+n;//n-1个数的和再加上n
}
}
你要理解了这种思想,就能理解汉诺塔的问题了。
E. 信道与编码若干实验题(要求用C语言编写)~求高手
嵌入式软件一般需着重考虑三个方面:性能、安全性和开发效率(包括代码可移植性等)。
性能(运行效率)方面,汇编明显是最高的。但汇编在安全性和开发效率方面明显是最低的(不考虑机器语言- -)。所以除非是要求极端高性能的嵌入式平台(或者是系统实在是太简单而没办法支持高级语言,orz- -),使用汇编语言的不多。
相对于C,其它高级语言的运行效率一般比较低(C程序运行效率可达汇编的80%,而其它程序可能只有C程序的80%),源代码和目标代码也可能会比较长。对于嵌入式系统,性能的瓶颈是非常致命的,很可能某种用C编写的程序可以达到预期目标,而用其它语言使用同样算法编写的程序就不行。(不过也正因为这个原因,在嵌入式系统上实现的可用编程语言并不多。)
基于系统的用途,安全性设计嵌入式系统也是必须考虑的一个部分(比如说用于医疗卫生设施),必须尽可能在开发期间减少潜在的错误。这方面C不占优势,但如果保证代码严格遵守安全规范,也可以接受(相对而言,汇编就郁闷了- -)。
开发效率和安全性类似,也在可接受范围之内。
F. c语言中的汉字问题
字符在计算机中是以编码的形式出现的,一个汉字占2个字节,声明一个数组:char ch[3];这里声明三个元素是因为要存放一个0,作为空终止字符,表示字符串结束,完整的式子:char ch[3]="寒";
G. C语言能不能使用中文变量名啊
C语言可以使用中文变量名。
c语言变量名规则是:
1、变量名以英文字母开头;
2、变量名中的字母是区分大小写的;
3、变量名不能是关键字;
4、变量名中不能包含空格、标点符号和类型说明符。
(7)汉明码c语言扩展阅读
C语言中定义的关键字有:
由ANSI标准定义的C语言关键字共32个:auto、 double、 int、 struct、 break 、else、 long、 switch、case、 enum、 register 、typedef、 char 、extern 、return、 union 、const、 float 、short、 unsigned、 continue、 for、 signed 、void、default 、goto、 sizeof 、volatile、 do 、if 、while、 static。
这32个关键字就是已经被C语言本身使用,不能作为其他用途使用,比如不能定义成变量名、函数名。
H. 如何用C语言实现十进制和汉明码之间的转换~
汉明码非常复杂的,有 UTF、UTF-8、GBK、GB2312 等
你给我一个十进制数值,我可以同时翻译出多个不同的汉字
I. 在c语言中如何定义汉子
你说的是汉字吧,如果是汉字的话可以用宽字符定义。宽字符 在ANSI/ISO 9899--1990也就是美国国家为程序设计语言C指定的标准(也称为ANSI C)中是这样定义的: 用多个字节来代表的字符称之为宽字符,而Unicode只是宽字符编码的一种实现,宽字符并不一定是Unicode。 在Windows 1.0(1985年11月发布)中,微软发布windows自有的字符集称为ANSI字符集,因为它是基于ANSI和ISO标准的一个草案,而此草案最终称为ANSI/ISO 8859-1--1987,这也简称为"拉丁语-1"。 在MS-DOS 3.3中把代码页的概念介绍给了IBM-PC的用户。这一概念也转接到Windows操作系统中。代码页定义了字符的响应字符码。原本的IBM字符集被称为第437页代码页,第850页是MS-DOS Latin 1.但是代码页的数量超乎清理地的剧增。 这里面存在的一个基本问题是世界上的书面语言文字根本无法用256个8位代码来表示。以前的那些涉及代码页和DBCS编码已经被证明是不足和笨拙的。那儿Unicode编码也应运而生。 UNICODE字符称为宽字符(特别是在C编程环境里),每一个Unicode字符时16位宽而不是8位,C语言用unsigned short表示,可以存放世界上所有书面语言的所有字符和象形文字,还包括一批数学符号和装饰标志的集合。Unicode最棒的一个地方是它只有一个字符集,这就避免了二义性。 当今时代,为了应用程序的国际化,应该提倡使用UNICODE来编写程序! VC++6.0之前没有关键字wchar_t,用unsigned short表示WCHAR; VC++7.0之后有了关键字wchar_t,用来表示WCHAR,及宽字符; Unicode 是支持所有字符集(包括无法以单个字节表示的字符集)的规范。为国际市场编程时应考虑使用 Unicode 或多字节字符集 (MBCS),或使程序能够通过更改开关来生成支持两种字符集之一的程序。 宽字符是双字节多语言字符代码。在当今的全球计算业内使用的大多数字符(包括技术符号和特殊的发布字符),都可以根据 Unicode 规范表示为宽字符形式。无法以 1 个宽字符表示的字符可以通过 Unicode 的代理项功能以 Unicode 对表示。由于每个宽字符总是以固定的 16 位大小表示,因此使用宽字符可以简化使用国际字符集进行的编程。 宽字符字符串表示为一个 wchar_t[] 数组并由 wchar_t* 指针指向它。可以通过用字母 L 作为字符的前缀将任何 ASCII 字符表示为宽字符形式。例如,L'\0' 是终止宽(16 位)NULL 字符。同样,可以通过用字母 L 作为 ASCII 字符串的前缀 (L"Hello") 将任何 ASCII 字符串表示为宽字符字符串形式。 通常,宽字符在内存中占用的空间比多字节字符多,但处理速度更快,因为很多系统的内核包括Windows NT内核都是从底层向上使用Unicode编码的。另外,在多字节编码中一次只能表示一个区域设置,Unicode编码可以毫无障碍的在世界上任何书面语言的字符中转换。
J. C语言编程 ASC码 海明码 循环冗余码
这……
需要一段时间编程啊
可以先用ch=getch();输入,然后用ch%2对每一位分离,顺序存进stack,然后倒序输出,就是ASC码了。
另外如果位运算学的好,可以用位运算做。
海明码和循环冗余码记得学过,但都还给老师了……不好意思