1.八数码C++源代码
2.c语言八进制怎么表示?
3.Dreamweaver8怎么生成源代码
4.源代码采用utf8 with bom还是字源utf8 no bom保存的相关问题
八数码C++源代码
#include<cstdio>
#include<vector>
#include<queue>
#include<ctime>
#define maxhash
#define hash(x) x%maxhash
using namespace std;
typedef unsigned long long ULL;
vector<ULL>list[maxhash];
vector<int>dist[maxhash];
inline int abs(int x)
{
return x<0?-x:x;
}
int hval[][];
void fill_hval(int *d)
{
for(int i=0;i<=8;i++)//number i
{
int pos;
for(int k=1;k<=9;k++)//i's position
if(d[k]==i)
{
pos=k;
break;
}
for(int j=1;j<=9;j++)
{
hval[i][j]=abs((j-1)/3-(pos-1)/3)+abs((j-1)%3-(pos-1)%3);
}
}
}
int h(ULL d)
{
int answer=0;
for(int i=9;i>=1;i--)
{
int x=d%;
d/=;
answer+=hval[x][i];
}
return answer;
}
int ToARR(ULL s,int *d)
{
int z=0;
for(int i=9;i>=1;i--)
{
d[i]=s%;
if(d[i]==0) z=i;
s/=;
}
return z;
}
ULL ToULL(int *d)
{
ULL ans=0;
for(int i=1;i<=9;i++)
ans=ans*+d[i];
return ans;
}
void insert(ULL x,int di)
{
ULL hx=hash(x);
list[hx].push_back(x);
dist[hx].push_back(di);
}
int find(ULL x)
{
ULL hx=hash(x);
int size=list[hx].size();
for(int i=0;i<size;i++)
if(x==list[hx][i]) return dist[hx][i];
return -1;
}
inline void swap(int &x,int &y)
{
int t=x;
x=y;
y=t;
}
struct state{
int step;
ULL x;
friend bool operator <(state a,state b)
{
return a.step>b.step;
}
};
int cnt=0;
void AStar(int *from,int *to)
{
priority_queue<state>q;
ULL x=ToULL(from);
ULL y=ToULL(to);
fill_hval(to);
q.push((state){ h(x),x});
insert(x,0);
int d[];
while(!q.empty())
{
cnt++;
state s=q.top();
ULL i=s.x; q.pop();
int step=find(i);
int z=ToARR(i,d);
//printf("%lld %d %d\n",i,step,z);
if(i==y) return;
if(z-3>0)
{
swap(d[z],d[z-3]);
ULL j=ToULL(d);
swap(d[z],d[z-3]);
if(find(j)!=-1) goto out1;
q.push((state){ step+h(j),j});
insert(j,step+1);
}
out1:
if(z+3<)
{
swap(d[z],d[z+3]);
ULL j=ToULL(d);
swap(d[z],d[z+3]);
if(find(j)!=-1) goto out2;
q.push((state){ step+h(j),j});
insert(j,step+1);
}
out2:
if(z%3!=0)
{
swap(d[z],d[z+1]);
ULL j=ToULL(d);
swap(d[z],d[z+1]);
if(find(j)!=-1) goto out3;
q.push((state){ step+h(j),j});
insert(j,step+1);
}
out3:
if(z%3!=1)
{
swap(d[z],d[z-1]);
ULL j=ToULL(d);
swap(d[z],d[z-1]);
if(find(j)!=-1) continue;
q.push((state){ step+h(j),j});
insert(j,step+1);
}
}
}
int from[],to[];
void work()
{
for(int i=1;i<=9;i++)
scanf("%d",&from[i]);
for(int i=1;i<=9;i++)
scanf("%d",&to[i]);
AStar(from,to);
ULL y=ToULL(to);
printf("%d ",find(y));
#ifdef DEBUG
printf("%d ",clock());
printf("%d ",cnt);
#endif
}
int main()
{
#ifdef DEBUG
freopen("debug.in","r",stdin);
freopen("debug.out","w",stdout);
#endif
work();
return 0;
}
这是基于曼哈顿距离的估价函数的Astar
c语言八进制怎么表示?
除了二进制,C语言还会使用到八进制。字源八进制是字源一种“逢八进一”的进制,它由 0~7 八个符号来描述。字源同样,字源此处通过十进制和八进制的字源抖音热点源码对比来描述八进制的表示方式。
八进制基数为8,字源加法运算时逢八进一,字源减法运算时借一当八。字源例如,字源数字 0、字源1、字源5、字源7、字源、字源、、 都是有效的八进制。
当使用八进制表示十进制数字8时,由于表示八进制的符号只有 0~7,因此,汇客魔方源码根据逢八进一的规则,需要向高位进一位,表示为。同理,使用八进制表示十进制数字时,继续向高位进一位,表示为 。
扩展资料
八进制转换为十进制的源代码如下
#include<stdio.h>
void main()
{
char *p,s[6];int n;
p=s;
printf("Please input a Octal number:");
gets(p);
n=0;
while(*(p)!='\0')
{
n=n*8+*p-'0';
p++;
}
printf("Octal number to Decimal number:%d",n);
}
Dreamweaver8怎么生成源代码
Dreamweaver8生成源代码方法步骤:1、创建css样式,点击窗口\css样式,老铁牛源码编译可以打开css样式编辑窗口,还可以直接在属性面板内创建。
2、点击属性面板的编辑规则,或者是css样式窗口的+号就可以打开新建css规则对话框。
3、选择要创建的css样式的内容。比如要为段落更改样式。
4、在弹出的在线语音合成源码定义对话框中,选择要更改的各种属性。比如把段落的字体大小改为px,字体颜色改为红色。
5、点击确定,发现段落中的文字就出现了相应的效果。在<head>中条件了css样式代码。
源代码采用utf8 with bom还是utf8 no bom保存的相关问题
在编程领域,选择源代码的encoding格式往往是个微妙且复杂的问题。这不仅牵涉到源代码的API集合工具源码可读性和兼容性,更影响到编译器的解析和执行。让我们深入探讨在不同开发环境中,如何妥善处理utf8编码格式的选择与BOM(Byte Order Mark)的使用。
首先,理解编码格式的含义至关重要。UTF-8是一种无符号、变长字符编码标准,能够表示几乎所有语言的字符。在UTF-8编码下,中文字符通常以三个字节表示,以确保字符的完整性和跨平台的兼容性。然而,这一编码标准在不同的开发环境和编译器中展现的兼容性并不相同。
在某些开发环境中,如Visual Studio,中文字符默认以GB编码处理,这会导致在使用UTF-8编码时遇到乱码问题。在这样的情况下,将文件保存为UTF-8编码是明智之举。然而,在选择UTF-8编码时,是否包含BOM则需要根据实际需求和兼容性考虑。
UTF-8 with BOM(即包含BOM的UTF-8编码)提供了一种方式,通过在文件开头添加四个字节的BOM来明确指示文件的编码类型,这在处理较旧版本的编译器或某些特定环境时更为有利。然而,一些编译器或环境并不支持或识别UTF-8 with BOM格式的文件,导致解析错误或文件读取问题。因此,选用UTF-8 no BOM(不包含BOM的UTF-8编码)成为更广泛兼容性的选择。
在实际开发中,避免在代码中混用非标准的换行符(如在某些编辑器中常见的不同换行格式),以及在文件保存时统一使用UTF-8 no BOM编码格式,可以显著减少因编码问题导致的编译错误和兼容性问题。特别是在包含中文注释或中文字符的代码中,这一点尤为重要。
综上所述,选择UTF-8 no BOM作为源代码的保存格式,可以有效避免因编码问题导致的编译错误和兼容性挑战。在进行代码编写时,保持编码格式的一致性和跨平台兼容性是提高代码质量和开发效率的关键因素。