c语言指针编程练习
#include<stdio.h>
#include<string.h>
#include<alloc.h>
#define MAXSIZE 20
typedef struct node{
char data;
struct node *next;
}StackNode;
typedef struct
{
struct node *top;
}LinkStack;
void Init_LS(LinkStack *ls) /*置空链栈 */
{ ls->top=NULL; }
int Empty_LS(LinkStack *ls) /*判栈空 */
{ return ls->top==NULL; }
void Push_LS(LinkStack *ls, char x) /*入栈 */
{ StackNode *p=(StackNode *)malloc(sizeof(StackNode));
p->data=x;
p->next=ls->top; /* 将元素x插入链栈顶 */
ls->top=p ;
}
int Pop_LS(LinkStack *ls, char *y) /* 出栈*/
{ StackNode *p;
if (Empty_LS(ls))
{ printf ("下溢!") ;
return 0;
}
else { *y=ls->top->data ;
p=ls->top ;
ls->top=p->next;
free (p) ;
return 1 ;
}
}
int GetTop(LinkStack *ls, char *y) /*取栈顶元素 */
{ if( Empty_LS(ls) )
{ printf ("下溢!") ;
return 0;
}
else {
*y=ls->top->data;
return 1 ;
}
}
#define ARRAYSIZE 20
void main()
{
int i=0,j=0;
StackNode *pp;
char m=' ';
char a[ARRAYSIZE],ch;
LinkStack *s;
LinkStack *top;
Init_LS(s);
printf("请输入一个字符串:\n");
while(m!='.') /*输入字符串,并过滤标点符号*/
{m=getchar();
if(m>='0' && m<='9' ||m>='A' && m<='Z' ||m>='a' && m<='z')
{a[i]=m;i++;}
}
for(j=0;j<i/2;++j) /* 字符串的前一半入栈*/
{
Push_LS(s,a[j]);
}
for(j=i-i/2;j<i;++j) /*出栈,与后一半字符串比较*/
{
Pop_LS(s,&ch);
if(ch!=a[j])
break;
}
if(!Empty_LS(s))
printf("否\n" );
else
printf("是\n" );
}
‘贰’ C语言编程题目 指针
C程序如下:
#include
"stdio.h"
#include<string>
#include<iostream>
using
namespace
std;
main()
{
string
Cons="12345678";
string
input;
const
char
*B=Cons.data();
const
char
*A;
cin>>input;
A=input.data();
int
lengthA=input.length();
int
lengthB=Cons.length();
for(int
i=0;i<lengthB;i++)
{
if(B[i]>A[i])
{
printf("输入的数小于原数");break;}
if(B[i]<A[i])
{
printf("输入的数大于原数");break;}
}
if(lengthA>lengthB&&lengthB==i)
printf("输入的数大于原数");
if(lengthA==lengthB&&lengthB==i)
printf("输入的数等于原数");
}
如果你说的是比较字符串大小就是这个程序了
进入后开始输入你要输入的字符串
‘叁’ C语言指针编程题,求大神解答
#include "stdio.h"
void fun(int a[][6],int n,int m,int *odd,int *even)
{int i,j;
*odd=*even=0;
for(i=0; i<n; i++)
for(j=0; j<m; j++)
a[i][j]%2?*odd+=a[i][j]:*even+=a[i][j];
}
int main()
{ int n,m,i,j,a[5][6],odd,even;
for(i=0; i<5; i++)
{ for(j=0; j<6; j++)
{ a[i][j]=i*6+j+1;
printf("%4d",a[i][j]);
}
printf(" ");
}
fun(a,5,6,&odd,&even);
printf("奇数之和=%d 偶数之和=%d ",odd,even);
return 0;
}
‘肆’ c语言指针的编程题
#include<stdio.h>
void
main()
{
char
str1[10],str2[10],*p;
int
i;
p=str1;
for(i=0;i<9;i++)
scanf("%c",&str1[i]);
str1[i]=
'\0';////该在str1[i]最后加一个'\0'要下面的结束for(i=0;*p;i++,p++)
就找不到结束符,所以后面就有乱码“烫烫”
for(i=0;*p;i++,p++)///你可以用i<10来直接截取字符的前十位是可以的但是只是截取,其实真是的str2仍然后面有乱码
str2[i]=*p;
str2[i]='\0';
printf("%s\n",str2);
}
‘伍’ C语言指针编程题,求助大神解答
#include<stdio.h>
int a[200];
void rotateArray(int *a,int n,int m){
m%=n; //这句是防止m大于n 结果会不正确的情况
for(int i=m;i<n;++i)scanf("%d",&a[i]);
for(int i=0;i<m;++i)scanf("%d",&a[i]);
}
int main(){
int n,m;
scanf("%d%d",&n,&m);
rotateArray(a,n,m);
printf("%d",a[0]);
for(int i=1;i<n;++i)printf(",%d",a[i]);
return 0;
}
‘陆’ C语言指针简单的编程题
intmain()
{
doublea[20];
doubleresult=0.0;
inti=0;
doublefact=3.2;
doubleval=1.5;
double*ptrDouble=&a[0];
//输出所有数组值
for(i=0;i<20;i++)
{
*(ptrDouble+i)=i*fact+val;
printf("%f",*(ptrDouble+i));
}
ptrDouble=&a[10];
//输出后是个值
for(i=0;i<10;i++)
{
result=result+*(ptrDouble+i);
}
printf("%f",result);
};
‘柒’ C语言 数组和指针编程题
// ConsoleApplication3.cpp : 定义控制台应用程序的入口点。
#include "stdafx.h"
void upCopy(char* new1, char* old)
{
while (*old)
{
if (65<=*old && *old<= 90) *new1++=*old;
old++;
}
*new1=0;
}
int main()
{
char s1[140]; //="";
char s0[]="foiwABEifjCDB";
upCopy(s1, s0);
printf("(%s%s",s1,")");
getchar();
return 0;
}
‘捌’ C语言指针一道简单的编程题
按照你的要求编写的C语言程序如下
include<stdio.h>
intmain()
{
inta,b;
int*p=&a;
a=30;
printf("a=%d ",*p);
p=&b;
scanf("%d",p);
a=*p+24;
printf("a=%d,b=%d",a,b);
return0;
}
运行结果
a=30
76
a=100,b=76
‘玖’ c语言指针编程题
int main()
{
double a[20];
double result = 0.0;
int i = 0;
double fact = 3.2;
double val = 1.5;
double *ptrDouble = &a[0];
//输出所有数组值
for (i = 0; i<20;i++)
{
*(ptrDouble + i) = i*fact+val;
printf("%f ",*(ptrDouble + i));
}
ptrDouble = &a[10];
//输出后是个值
for (i = 0; i<10;i++)
{
result = result + *(ptrDouble+i);
}
printf("%f",result);
};
‘拾’ c语言 指针部分编程题
#include<stdio.h>
#include<stdlib.h>
intswap(int*a,int*b)
{
inttemp;
temp=*a;*a=*b;*b=temp;
return0;
}
intmain()
{
int*p1=malloc(sizeof(int));
int*p2=malloc(sizeof(int));
int*p3=malloc(sizeof(int));
scanf("%d%d%d",p1,p2,p3);
if(*p1<*p2){
swap(p1,p2);
if(*p1<*p3){
swap(p1,p3);
if(*p2<*p3)
swap(p2,p3);
}else{
if(*p2<*p3)
swap(p2,p3);
}
}else{
if(*p1<*p3){
swap(p1,p3);
if(*p2<*p3)
swap(p2,p3);
}else{
if(*p2<*p3)
swap(p2,p3);
}
}
printf("%d%d%d",*p1,*p2,*p3);
return0;
}
运行结果