C++程序设计的几个题目

题目还是够简单的,我也试过自己编,无奈那程序老是不能运行,我都抓狂得想砸手机了。请尽量发能够运行的完整程序代码上来,能答几个算几个吧,我在线等,有好的不惜把所有的分全追加... 题目还是够简单的,我也试过自己编,无奈那程序老是不能运行,我都抓狂得想砸手机了。
请尽量发能够运行的完整程序代码上来,能答几个算几个吧,我在线等,有好的不惜把所有的分全追加上去。

1.编程推算:前两位数字相同,后两位数字也相同的完全平方数。
2.用1-9九个数字填九宫格,纵横斜向之和相等,要求输出所有可能结果。
(这两题要求不要动用数学方面的计算方法)
3.用条件编译方法实现:
输入一行电报文字,任选两种输出方式:1.原文输出;2.将字母变成其下一个字母输出(如a变成b,b变成c……z变成a,其他字符不变)
4.用指向指针的方法对n个整数排序并输出。
要求将排序单独写成一个函数,整数在主函数中输入、输出。
(注意用指向指针的方法,冒泡法的不要弄上来。)
5.用指针和函数的知识找出一个矩阵中的最大值、最小值和相同元素所在的行列号,并输出这些值。要求程序具有一定的通用性。
今天我等到十点半,再没人我明天再提个问题链接到这里来。
所有的问题后天必须解决了,我等着写报告呢。

第一个答案是对的,但是我们没学过【自己汗一个先】,我们现在还在基础中的基础原地踏步,基本上没怎么用过系统默认函数,比如说我刚刚弄通过的第一题程序【好艰难哪】:
#include<iostream>
using namespace std;
void main()
{
int a,b,c,d,i,n;
for(i=40;i<100;i++)
{
n=i*i;
a=int(n/1000);
b=int(n-a*1000)/100;
c=int(n-a*1000-b*100)/10;
d=n-a*1000-b*100-c*10;
if(a==b && c==d)
break;
}
cout<<n<<endl;
}
展开
 我来答
匿名用户
2009-06-29
展开全部
真是服了你了,这么多问题,还这么多要求。你可知道就第二题一题都值200分最少,给你写了这么多代码而且都是调试编译通过的,还不满足啊?你应该很满意了,碰到我是你运气,你慢慢就知道了。我你可遇不可得。
算法是程序的灵魂,给你一些简洁高效代码:
第一题:
#include <stdio.h>
#include <stdlib.h>

int main()
{
int i;
char s[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");
return 0;
}

第二题:
智力游戏九宫格简练代码
#include <stdio.h>
#include <stdlib.h>

int a[]={0,1,2,5,8,7,6,3}; /*指针数组.依次存入矩阵中构成环的元素下标*/
int b[9]; /*表示3X3矩阵,b[4]为空格*/
int c[9]; /*确定1所在的位置后,对环进行调整的指针数组*/
int count=0; /*数字移动步数计数器*/

void print(void) /*按格式要求输出矩阵*/
{
int c;
printf(" >> Step No.%2d ",count++);
for(c=0;c<9;c++)
if(c%3==2) printf("%2d ",b[c]);
else printf("%2d",b[c]);
printf("\n");
}

int main()
{
int i,j,k,t;

system("cls");
printf(" >> Please enter original order of digits 1-8: ");
for(i=0;i<8;i++)
scanf("%d",&b[a[i]]);
/*顺序输入矩阵外边的8个数字,矩阵元素的顺序由指针数组的元素a[i]控制*/
printf("The sorting process is as felow:\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;
}
else if(b[c[j]]==i) break; /*数字i在正确的位置*/

system("pause");
return 0;
}

第三--第五题太没挑战性,无激情。
第三题:
#include <stdio.h>
#include <stdlib.h>

int isLetter(char c)
{
if((c>='A'&&c<='Z') || (c>='a'&&c<='z'))
return 1;
else
return 0;
}

void translate(char s[])
{
int i;
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';
}
}

int main()
{
char ch,s[256];
puts("Please input your string:");
gets(s);

puts("Encrypt or not?(y/n):");
ch=getchar();
puts("The result is:");
if(ch=='Y'||ch=='y')
{
translate(s);
}
puts(s);

system("pause");
return 0;
}

第四题:
#include <stdio.h>
#include <stdlib.h>

void sort(int* p,int n)
{
int i,j,k,temp;
for(i=0;i<n-1;i++)
for(j=i+1;j<n;j++)
{
k=i;
if(*(p+k)>*(p+j))k=j;
if(k!=i)
{
temp=*(p+i);
*(p+i)=*(p+k);
*(p+k)=temp;
}
}
}

int main()
{
int a[1024],i,num;
printf("Please input numbers of array:");
scanf("%d",&num);
printf("Please input %d elements of array:\n",num);
for(i=0;i<num;i++)
scanf("%d",&a[i]);
sort(a,num);
printf("The result is:\n");
for(i=0;i<num;i++)
printf("%-5d",a[i]);
printf("\n");

system("pause");
return 0;
}

第五题:
#include <stdio.h>
#include <stdlib.h>
#define MAXN 20
#define MAXM 20

int a[MAXN][MAXM];

int main()
{
int i,j,m,n,min,max;
printf("Please input rank and column of matrix:");
scanf("%d%d",&m,&n);
printf("Please input %d elements of the matrix:\n",m*n);
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);
max=min=a[0][0];
for(i=0;i<m;i++)
for(j=0;j<n;j++)
{
if(a[i][j]<min)
{
min=a[i][j];
}
else if(a[i][j]>max)
{
max=a[i][j];
}
}
printf("The minium is: %d\nThe maxium is: %d\n",min,max);

system("pause");
return 0;
}

------------------------------------------------------------
#include<iostream>
using std::endl;
using std::cout;

int main()
{
int a,b,c,d,i,n;
for(i=32;i<100;i++)
{
n=i*i;
a=n/1000;//整数除以整数结果当然是整数了
b=(n-a*1000)/100;
c=(n%100)/10;
d=n%10;
if(a==b && c==d)
cout<<n<<" ";//还没计算怎么知道答案只有一个?
}
cout<<endl;

system("pause");
return 0;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式