return0;
}
7
1.编程推算:
前两位数字相同,后两位数字也相同的完全平方数。
#include
#include
intmain()
{
inti;
chars[5];
for(i=32;i<=99;i++)
{
sprintf(s,"%d",i*i);
if(s[0]==s[1]&&s[2]==s[3])
printf("%s",s);
}
system("pause");
return0;
}
8
用1-9九个数字填九宫格,纵横斜向之和相等,要求输出所有可能结果。
#include
#include
inta[]={0,1,2,5,8,7,6,3};/*指针数组.依次存入矩阵中构成环的元素下标*/
intb[9];/*表示3X3矩阵,b[4]为空格*/
intc[9];/*确定1所在的位置后,对环进行调整的指针数组*/
intcount=0;/*数字移动步数计数器*/
voidprint(void)/*按格式要求输出矩阵*/
{
intc;
printf(">>StepNo.%2d",count++);
for(c=0;c<9;c++)
if(c%3==2)printf("%2d",b[c]);
elseprintf("%2d",b[c]);
printf("\n");
}
intmain()
{
inti,j,k,t;
system("cls");
printf(">>Pleaseenteroriginalorderofdigits1-8:
");
for(i=0;i<8;i++)
scanf("%d",&b[a[i]]);
/*顺序输入矩阵外边的8个数字,矩阵元素的顺序由指针数组的元素a[i]控制*/
printf("Thesortingprocessisasfelow:
\n");
print();
for(t=-1,j=0;j<8&&t==-1;j++)/*确定数字1所在的位置*/
if(b[a[j]]==1)t=j;/*t:
记录数字1所在的位置*/
for(j=0;j<8;j++)/*调整环的指针数组,将数字1所在的位置定为环的首*/
c[j]=a[(j+t)%8];
for(i=2;i<9;i++)/*从2开始依次调整数字的位置*/
/*i:
正在处理的数字,i对应在环中应当的正确位置就是i-1*/
for(j=i-1;j<8;j++)/*从i应处的正确位置开始顺序查找*/
if(b[c[j]]==i&&j!
=i-1)/*若i不在正确的位置*/
{
b[4]=i;/*将i移到中心的空格中*/
b[c[j]]=0;print();/*空出i原来所在的位置,输出*/
for(k=j;k!
=i-1;k--)/*将空格以前到i的正确位置之间的数字依次向后移动一格*/
{
b[c[k]]=b[c[k-1]];/*数字向后移动*/
b[c[k-1]]=0;
print();
}
b[c[k]]=i;/*将中间的数字i移入正确的位置*/
b[4]=0;/*空出中间的空格*/
print();
break;
}
elseif(b[c[j]]==i)break;/*数字i在正确的位置*/
system("pause");
return0;
}
9
用条件编译方法实现:
输入一行电报文字,任选两种输出方式:
1.原文输出;2.将字母变成其下一个字母输出(如a变成b,b变成c……z变成a,其他字符不变)
#include
#include
intisLetter(charc)
{
if((c>='A'&&c<='Z')||(c>='a'&&c<='z'))
return1;
else
return0;
}
voidtranslate(chars[])
{
inti;
for(i=0;s[i]!
='\0';i++)
if(isLetter(s[i]))
{
if(s[i]>='A'&&s[i]<='Z')
s[i]=(s[i]-'A'+1)%26+'A';/*取模方法可避免字符出界*/
else
s[i]=(s[i]-'a'+1)%26+'a';
}
}
intmain()
{
charch,s[256];
puts("Pleaseinputyourstring:
");
gets(s);
puts("Encryptornot?
(y/n):
");
ch=getchar();
puts("Theresultis:
");
if(ch=='Y'||ch=='y')
{
translate(s);
}
puts(s);
system("pause");
return0;
}
10
用指向指针的方法对n个整数排序并输出。
要求将排序单独写成一个函数,整数在主函数中输入、输出。
#include
#include
voidsort(int*p,intn)
{
inti,j,k,temp;
for(i=0;ifor(j=i+1;j{
k=i;
if(*(p+k)>*(p+j))k=j;
if(k!
=i)
{
temp=*(p+i);
*(p+i)=*(p+k);
*(p+k)=temp;
}
}
}
intmain()
{
inta[1024],i,num;
printf("Pleaseinputnumbersofarray:
");
scanf("%d",&num);
printf("Pleaseinput%delementsofarray:
\n",num);
for(i=0;iscanf("%d",&a[i]);
sort(a,num);
printf("Theresultis:
\n");
for(i=0;iprintf("%-5d",a[i]);
printf("\n");
system("pause");
return0;
}