Anda di halaman 1dari 6

/*Branch and Bound Algorithm for Travelling Sales Person*/ #include<stdio.h> #include<conio.

h> int a[10][10],visited[10],n,cost=0; void get() { int i,j; printf(Enter No. of Cities: ); scanf(%d,&n); printf(\nEnter Cost Matrix: \n); for( i=0;i<n;i++) { printf(\n Enter Elements of Row # : %d\n,i+1); for( j=0;j<n;j++) scanf(%d,&a[i][j]); visited[i]=0; } printf(\n\nThe cost list is:\n\n); for( i=0;i<n;i++) { printf(\n\n); for( j=0;j<n;j++) printf(\t%d,a[i][j]); } } void mincost(int city) { int i,ncity; visited[city]=1; printf(%d >,city+1); ncity=least(city); if(ncity==999) { ncity=0; printf(%d,ncity+1); cost+=a[city][ncity]; return; } mincost(ncity); } int least(int c) { int i,nc=999; int min=999,kmin; for(i=0;i<n;i++)

{ if((a[c][i]!=0)&&(visited[i]==0)) if(a[c][i]<min) { min=a[i][0]+a[c][i]; kmin=a[c][i]; nc=i; } } if(min!=999) cost+=kmin; return nc; } void put() { printf(\n\nMinimum cost:); printf(%d,cost); } void main() { clrscr(); get(); printf(\n\nThe Path is:\n\n); mincost(0); put(); getch(); } Input Sample: No. of Nodes : 6 Cost Matrix: 99 10 15 20 5 99 9 10 6 13 99 12 8 8 9 99 99 10 99 6 10 99 5 99

99 8 99 6 99 99

8 99 5 99 99 99

Share this: StumbleUpon Digg Reddit

/*PASS ONE OF LINKING LOADER*/ #include<stdio.h> #include<conio.h> #include<stdlib.h> #include<string.h> void main() { FILE *in,*es,*address; int progaddr,csaddr,cslth,value; char type[10],addr[10],obj[10],mflag[10]; clrscr(); printf(Enter the starting address(OS)\n); scanf(%d,&progaddr); csaddr=progaddr; in=fopen(OBJECT.TXT,r); es=fopen(ESTAB.TXT,w); address=fopen(ADDRESS.TXT,w); fprintf(address,%d,progaddr); fclose(address); fscanf(in,%s\t%s\t%s\t%s,type,addr,obj,mflag); while(!feof(in)) { cslth=atoi(obj); fprintf(es,%s\t-\t%d\t%s\n,addr,csaddr,obj); do { fscanf(in,%s\t%s\t%s\t %s,type,addr,obj,mflag); if(strcmp(type,D)==0) { value=csaddr+atoi(obj); fprintf(es,-\t %s\t%d\t-\n,addr,value); } }while(strcmp(type,E)!=0); csaddr=csaddr+cslth; fscanf(in,%s\t%s\t%s\t%s,type,addr,obj,mflag); } fclose(in); fclose(es); getch(); } OUTPUT: Enter the starting [...]

Relocation Loader #include<stdio.h> #include<conio.h> #include<string.h> #include<stdlib.h> struct object_code { int locctr; char add[10]; }obcode[300]; void main() { char input[100][16], output[100][16], binary[20], address[20], stloc[10]; int len, bitmask, loc, tlen=0, tloc, textloc, i=0, location, j, k, count=0, start, n, num=0, inc=0; FILE *fp1, *fp2; clrscr(); fp1=fopen(linput.dat, r); fp2=fopen(loadout.dat, w); printf(Enter the location where the program has to [...]
July 30, 2009 Categories: System Software . Tags: C, SS . Author:

/* knapsack problem using backtracking*/


/* Variable Description. n Total no. of items available w[] Weight of each item p[] Profit of each item m Maximum Capacity of the Sack unit[] Profit of each item per Unit p[]/w[] x[] Final list of items put into the Sack y[] Intermediate list of selected items fp Final Profit fw Final Weight cp Current Profit cw Current Weight */ #include <stdio.h> #include <conio.h> #define max 10 int w[max],i,j,p[max]; int n,m; float unit[max]; int y[max],x[max],fp=-1,fw; void get()

{ printf(\n Enter total number of items: ); scanf(%d,&n); printf(\n Enter the Maximum capacity of the Sack: ); scanf(%d,&m); for(i=0;i<n;i++) { printf(\n Enter the weight of the item # %d : ,i+1); scanf(%d,&w[i]); printf(\n Enter the profit of the item # %d : , i+1); scanf(%d, &p[i]); } } void show() { float s=0.0; printf(\n\tItem\tWeight\tCost\tUnit Profit\tSelected ); for(i=0;i<n;i++) printf(\n\t%d\t%d\t%d\t%f\t%d,i+1,w[i],p[i],unit[i],x[i]); printf(\n\n The Sack now holds following items : ); for(i=0;i<n;i++) if(x[i]==1) { printf(%d\t,i+1); s += (float) p[i] * (float) x[i]; } printf(\n Maximum Profit: %f ,s); } /*Arrange the item based on high profit per Unit*/ void sort() { int t,t1; float t2; for(i=0;i<n;i++) unit[i] = (float) p[i] / (float) w[i]; for(i=0;i<n-1;i++) { for(j=i+1;j<n;j++) { if(unit[i] < unit[j]) { t2 = unit[i]; unit[i] = unit[j]; unit[j] = t2; t = p[i]; p[i] = p[j]; p[j] = t; t1 = w[i];

w[i] = w[j]; w[j] =t1; } } } } float bound(float cp,float cw,int k) { float b = cp; float c = cw; for(i=k;i<=n;i++) { c = c+w[i]; if( c < m) b = b +p[i]; else return (b+(1-(c-m)/ (float)w[i])*p[i]); } return b; } void knapsack(int k,float cp,float cw) { if(cw+w[k] <= m) { y[k] = 1; if(k <= n) knapsack(k+1,cp+p[k],cw+w[k]); if(((cp+p[k]) > fp) && ( k == n)) { fp = cp+p[k]; fw = cw+w[k]; for(j=0;j<=k;j++) x[j] = y[j]; } } if(bound(cp,cw,k) >= fp) { y[k] = 0; if( k <= n) knapsack(k+1,cp,cw); if((cp > fp) && (k == n)) { fp = cp; fw = cw; for(j=0;j<=k;j++) x[j] = y[j]; } }

} void main() { clrscr(); printf(\n\n\n\t\t ******** KNAPSACK PROBLEM ********); printf(\n\t\t ); get(); printf(\n The Sack is arranged in the order\n); sort(); knapsack(0,0.0,0.0); show(); getch(); } Output: ******** KNAPSACK PROBLEM ******** Enter total number of items: 3 Enter the Maximum capacity of the Sack: 25 Enter the weight of the item # 1 : 1 Enter the profit of the item # 1 : 11 Enter the weight of the item # 2 : 11 Enter the profit of the item # 2 : 21 Enter the weight of the item # 3 : 21 Enter the profit of the item # 3 : 31 The Sack is arranged in the order Item Weight Cost Unit Profit Selected 1 1 11 11.000000 1 2 11 21 1.909091 0 3 21 31 1.476190 1 The Sack now holds following items : 1 3 Maximum Profit: 42.000000 Reference:

Anda mungkin juga menyukai